嗨,我想读取 xlsx 文件或 xls 文件是什么。XSSF 可以支持 xls 文件吗?还是我需要为这两种文件编写单独的代码?
问问题
15842 次
6 回答
5
是的,您可以使用 Apache POI 来读取和写入 xlsx 和 xls文件。
于 2011-01-17T10:26:37.383 回答
2
如果您希望您的代码适用于两者,则必须使用该org.apache.poi.ss
包。创建此包是为了统一 XSSF 和 HSSF。
于 2011-01-17T10:26:47.220 回答
2
对于我的一个项目,我创建了一个使用 Apache POI 和 OpenCSV 并且可以读取 xlsx、xls 和 csv 文件的基本实用程序。
给定一个转换器,它可以将行转换为对象,如下所示:
RowConverter<Country> converter = (row) -> new Country(row[0], row[1]);
ExcelReader<Country> reader = ExcelReader.builder(Country.class)
.converter(converter)
.withHeader()
.csvDelimiter(';')
.sheets(1)
.build();
List<Country> list;
list = reader.read("CountryCodes.xlsx");
list = reader.read("CountryCodes.xls");
list = reader.read("CountryCodes.csv");
您可以在github上找到该项目。
于 2015-02-20T09:50:02.797 回答
0
将此用于 xls 和 xlsx
Workbook wb_xssf; //Declare XSSF WorkBook
Workbook wb_hssf; //Declare HSSF WorkBook
Sheet sheet=null; //sheet can be used as common for XSSF and HSSF WorkBook
if(fileBean.getFileExt().equalsIgnoreCase("xls")){
wb_hssf = new HSSFWorkbook();
sheet = wb_hssf.getSheetAt(0);
}else if (fileBean.getFileExt().equalsIgnoreCase("xlsx")){
wb_xssf = new XSSFWorkbook(fileBean.getFileInput());
sheet = wb_xssf.getSheetAt(0);
}
于 2013-12-09T04:11:30.783 回答
0
你可以试试这个 xlsx 文件:
首先,您需要以下 jar 下载:
- dom4j-2.1.0.jar
- poi-3.17.jar
- poi-ooxml-3.17.jar
- commons-collections4-4.1.jar
- xmlbeans-2.3.0.jar
其次,在您的工作区中添加以下导入:
import org.apache.poi.ss.usermodel.*;
import java.io.File;
import java.io.IOException;
import java.io.FileInputStream;
import org.apache.poi.xssf.usermodel.XSSFSheet;
import org.apache.poi.xssf.usermodel.XSSFWorkbook;
第三,开始构建你的方法,例如读取使用这个:
public void ReadExcelFiles(String pathxlsx,javax.swing.JTable jtable) throws IOException{
//String nameSheet;
File file = new File(pathxlsx);
FileInputStream fis = new FileInputStream(file);
XSSFWorkbook wb = new XSSFWorkbook(fis);
// nameSheet=wb.getSheetName(0);
//XSSFSheet sh = wb.getSheet(nameSheet);
XSSFSheet sh = wb.getSheetAt(0);
System.out.println(sh.getLastRowNum());
System.out.println("Name: "+sh.getSheetName());
Row row = sh.getRow(6);
System.out.println(row.getRowNum());
System.out.println("columna "+row.getCell(1).getStringCellValue());
System.out.println("columna "+row.getCell(2).getStringCellValue());
System.out.println("columna "+row.getCell(3).getStringCellValue());
System.out.println("columna "+row.getCell(4).getStringCellValue());
System.out.println("Val: "+sh.getRow(4).getCell(6).getStringCellValue());
}
于 2018-03-19T15:08:35.753 回答
0
您可以使用以下代码并进行更改(取决于您的需要):
public void parseXLSX() {
String pathToXLSX = "file.xlsx";
File file = new File(pathToXLSX);
FileInputStream in = null;
try {
in = new FileInputStream(file);
XSSFWorkbook workbook = new XSSFWorkbook(in);
for (int i = 0; i < workbook.getNumberOfSheets(); i++) {
XSSFSheet sheet = workbook.getSheetAt(i);
int rowNumber = sheet.getLastRowNum() + 1;
for (int j = 1; j < rowNumber; j++) {
Iterator it = sheet.getRow(j).cellIterator();
while (it.hasNext()) {
System.out.println(it.next().toString());
}
}
}
} catch (IOException ex) {
ex.getMessage();
ex.printStackTrace();
} finally {
if (in != null) {
try {
in.close();
} catch (IOException ex) {
ex.getMessage();
ex.printStackTrace();
}
}
}
}
于 2019-01-29T13:19:23.300 回答