java读取excel报错
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了java读取excel报错相关的知识,希望对你有一定的参考价值。
import java.io.FileInputStream;
import org.apache.poi.xssf.usermodel.XSSFCell;
import org.apache.poi.xssf.usermodel.XSSFRow;
import org.apache.poi.xssf.usermodel.XSSFSheet;
import org.apache.poi.xssf.usermodel.XSSFWorkbook;
public class ExcelTest
public static void main(String[] args)
String fileToBeRead = "F:\\excel.xls";
try
XSSFWorkbook workbook = new XSSFWorkbook(new FileInputStream(fileToBeRead)); // 创建对Excel工作簿文件的引用
XSSFSheet sheet = workbook.getSheet("test"); // 创建对工作表的引用
int rows = sheet.getPhysicalNumberOfRows();//获取表格的
for (int r = 0; r < rows; r++) //循环遍历表格的行
String value = "";
XSSFRow row = sheet.getRow(r); //获取单元格中指定的行对象
if (row != null)
int cells = row.getPhysicalNumberOfCells();//获取单元格中指定列对象
for (short c = 0; c < cells; c++) //循环遍历单元格中的列
XSSFCell cell = row.getCell((short) c); //获取指定单元格中的列
if (cell != null)
if (cell.getCellType() == XSSFCell.CELL_TYPE_STRING) //判断单元格的值是否为字符串类型
value += cell.getStringCellValue() + ",";
else if (cell.getCellType() == XSSFCell.CELL_TYPE_NUMERIC) //判断单元格的值是否为数字类型
value += cell.getNumericCellValue() + ",";
else if (cell.getCellType() == XSSFCell.CELL_TYPE_BOOLEAN) //判断单元格的值是否为布尔类型
value += cell.getStringCellValue() + ",";
String[] str = value.split(",");
System.out.println(value);
catch (Exception e)
e.printStackTrace();
报如下错误:The supplied data appears to be in the Office 2007+ XML. You are calling the part of POI that deals with OLE2 Office Documents. You need to call a different part of POI to process this data (eg XSSF instead of HSSF)
XSSFWorkbook:是操作Excel2007的版本,扩展名是.xlsx
换成excel2007 试试追问
不行的,换了还是有问题,报的错一样
追答你确定你是换的excel2007
不是直接改后缀名
我的excel就是2007的。程序里本来写的也是.xlsx,只是因为出错才改了后缀。
追答直接改后缀名是不可以的
用另存为来改变后缀名
java读取excel文件,怎么取日期列?
不管我在excel文件中怎么设置日期列的格式,后台总是货到一串数字,导致我后台解析Date报错,用getDateCellValue()方法也没有用,请教一下,这种问题要怎么处理。。
参考技术A 一、定义excel的格式为普通文本,读出来永远都是String格式的字符串,再通过字符串转时间。二、定义为时间格式的,读取用getDateCellValue。
如果你这样一直读出来都是数字的话,转为long的毫秒,再转为date。
那个数字是日期距离1900年1月1日的天数 参考技术B 直接在如期类型之后将其转换成String格式的直接输出就好了啊
row.createCell(12).setCellValue(person.getNowDate().toString());
读入的时候再强制转换回来本回答被提问者和网友采纳 参考技术C 直接在如期类型之后将其转换成String格式的直接输出就好了啊
row.createCell(12).setCellValue(person.getNowDate().toString());
读入的时候再强制转换回来 参考技术D 这个问题我也遇到过 excle读取日期 导入到数据库里面的的日期格式就是12-6-27 所以要做下处理 给你个例子: import com.ibm.icu.text.SimpleDateFormat; class p public static void main(String[] args) String s= "12-07-03";//你取得的日...
以上是关于java读取excel报错的主要内容,如果未能解决你的问题,请参考以下文章
阿里的easyexcel导入读取Excel使用 报错ClassNotFoundException解决
jxl读取excel导入到数据库,报错java.lang.NoClassDefFoundError: jxl/read/biff/BiffException