从Excel读数据的问题

cnyiwei 2006-04-13 07:27:20
1.我用POI从Excel读取日期数据,月份为什么是00?即Excel中是2006-4-11,显示出来的是2006-00-11
代码如下:
ChangeDateFormat.java
---------------------------------------
package changeDate;

import java.text.*;
import java.util.Date;
public class ChangeDateFormat {
public String ChangeToYYMMDD(Date fullDate){
SimpleDateFormat sdf=new SimpleDateFormat("yyyy-MM-dd");
String date=sdf.format(fullDate);
return date;
}
}
-------------------------------------------
showtable.jsp
-------------------------------------------
<%@ page contentType="text/html;charset=GBK"%>
<meta http-equiv="Content-Type" content="text/html; charset=GBK">
<%@ page import="java.io.*,changeDate.ChangeDateFormat,org.apache.poi.hssf.usermodel.*"%>
<table align="center" border=1>

<%
//读取.xls
String filename=request.getParameter("filename");
HSSFWorkbook workbook = new HSSFWorkbook(new FileInputStream(filename));
// 创建对工作表的引用。
// 本例是按名引用,
HSSFSheet sheet = workbook.getSheetAt(0);
// 也可用getSheetAt(int index)按索引引用,
// 在Excel文档中,第一张工作表的缺省索引是0,
// 其语句为:HSSFSheet sheet = workbook.getSheetAt(0);
int i=0;
// 读取一行
HSSFRow row = sheet.getRow(i);
HSSFCell cell;
ChangeDateFormat cdf=new ChangeDateFormat();
while(row!=null){
%>
<tr>
<%
cell = row.getCell((short)0);
java.util.Date time=cell.getDateCellValue();
String timestr=cdf.ChangeToYYMMDD(time);
%>
<td align="center"><%=timestr%></td>
<%cell = row.getCell((short)1);
%>
<td align="center"><%=cell.getNumericCellValue()%></td>
<%
cell = row.getCell((short)2);
%>
<td align="center"><%=cell.getStringCellValue()%></td>
<%
cell = row.getCell((short)3);
%>
<td align="center">1</td>
<%
cell = row.getCell((short)4);
%>
<td align="center">1</td>
<%
cell = row.getCell((short)5);
%>
<td align="center">1</td>
<%
cell = row.getCell((short)6);
%>
<td align="center">1</td>
<%
cell = row.getCell((short)7);
%>
<td align="center">1</td>
<%
cell = row.getCell((short)8);
%>
<td align="center">1</td>
</tr>
<%
i=i+1;
row=sheet.getRow(i);
}
%>
</table>
...全文
190 7 打赏 收藏 转发到动态 举报
写回复
用AI写文章
7 条回复
切换为时间正序
请发表友善的回复…
发表回复
cnyiwei 2006-04-15
  • 打赏
  • 举报
回复
不是时区问题,是Excel中数据格式的转换问题,已经解决了,谢谢曾曾胡!
interpb 2006-04-13
  • 打赏
  • 举报
回复
可能是时区的问题

cnyiwei 2006-04-13
  • 打赏
  • 举报
回复
没格式化之前,日期的值是:Tue Apr 11 00:00:00 GMT 2006
cnyiwei 2006-04-13
  • 打赏
  • 举报
回复
嗯,interpb(曾曾胡)兄,如果把我这个问题解决,这100分就是你的了,嘿嘿
interpb 2006-04-13
  • 打赏
  • 举报
回复
cell = row.getCell((short)0);
java.util.Date time=cell.getDateCellValue();

刚取出来 ,没有格式化之前 time的值是?

打出来看看
String timestr=cdf.ChangeToYYMMDD(time);
interpb 2006-04-13
  • 打赏
  • 举报
回复
我来看看

cnyiwei 2006-04-13
  • 打赏
  • 举报
回复
晕啊,没人帮我作答啊。。。

81,094

社区成员

发帖
与我相关
我的任务
社区描述
Java Web 开发
社区管理员
  • Web 开发社区
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧