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)

HSSFWorkbook:是操作Excel2003以前(包括2003)的版本,扩展名是.xls
XSSFWorkbook:是操作Excel2007的版本,扩展名是.xlsx

换成excel2007 试试追问

不行的,换了还是有问题,报的错一样

追答

你确定你是换的excel2007

不是直接改后缀名

追问

我的excel就是2007的。程序里本来写的也是.xlsx,只是因为出错才改了后缀。

追答

直接改后缀名是不可以的

用另存为来改变后缀名

参考技术A Excel的版本不对,把Excel另存为.xls的就可以了

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报错的主要内容,如果未能解决你的问题,请参考以下文章

Java中poi读取含有失效超链接的Excel2007报错

阿里的easyexcel导入读取Excel使用 报错ClassNotFoundException解决

用pandas读取excel报错

java poi读取xls数据是出错

R读取excel文件的最佳方式

jxl读取excel导入到数据库,报错java.lang.NoClassDefFoundError: jxl/read/biff/BiffException