java - 如何使用 poi 在 java 中读取 excel(.xlsx)?

标签 java apache-poi

我正在尝试在 java 中读取 excel。我有以下代码。

import java.io.FileInputStream;
import java.io.IOException;
import java.io.InputStream;
import java.util.Iterator;
import org.apache.poi.ss.usermodel.Cell;
import org.apache.poi.ss.usermodel.DateUtil;
import org.apache.poi.ss.usermodel.Row;
import org.apache.poi.ss.usermodel.Sheet;
import org.apache.poi.ss.usermodel.Workbook;
import org.apache.poi.xssf.usermodel.XSSFWorkbook;

public class Test {
    public static void main(String[] args) throws IOException {
        String fname = "D:\\Test.xlsx"; // or "C:\\Test.xls" C:\\SDI-XL.xls
        InputStream inp = new FileInputStream(fname);
        Workbook  wb = new XSSFWorkbook(inp); // Declare XSSF WorkBook
        Sheet sheet = wb.getSheetAt(0); // sheet can be used as common for XSSF and HSSF

        Iterator<Row> rows=sheet.rowIterator();
        while (rows.hasNext()) {
            Row row = (Row) rows.next();
            System.out.println("row#=" + row.getRowNum() + "");
            Iterator cells = row.cellIterator();
            while (cells.hasNext()) {
                Cell cell = (Cell) cells.next();

                switch (cell.getCellType()) {
                case Cell.CELL_TYPE_STRING:
                    System.out.println(cell.getRichStringCellValue().getString());
                    break;
                case Cell.CELL_TYPE_NUMERIC:
                    if (DateUtil.isCellDateFormatted(cell)) {
                        System.out.println(cell.getDateCellValue() + "");
                    } else {
                        System.out.println(cell.getNumericCellValue());
                    }
                    break;
                case Cell.CELL_TYPE_BOOLEAN:
                    System.out.println(cell.getBooleanCellValue() + "");
                    break;
                case Cell.CELL_TYPE_FORMULA:
                    System.out.println(cell.getCellFormula());
                    break;
                default:
                }
            }
        }
        inp.close();
    }
}

我正在导入 poi.3.6jar 和 poi.ooxml-3.6 jar。 当我运行这个程序时,我收到了以下错误消息。

Exception in thread "main" java.lang.NoClassDefFoundError: org/apache/xmlbeans/XmlException
    at Test.main(Test.java:16)
Caused by: java.lang.ClassNotFoundException: org.apache.xmlbeans.XmlException
    at java.net.URLClassLoader$1.run(URLClassLoader.java:366)
    at java.net.URLClassLoader$1.run(URLClassLoader.java:355)
    at java.security.AccessController.doPrivileged(Native Method)
    at java.net.URLClassLoader.findClass(URLClassLoader.java:354)
    at java.lang.ClassLoader.loadClass(ClassLoader.java:423)
    at sun.misc.Launcher$AppClassLoader.loadClass(Launcher.java:308)
    at java.lang.ClassLoader.loadClass(ClassLoader.java:356)
    ... 1 more

我不明白为什么会出现此错误消息。所以请帮助我。

最佳答案

添加以下jar文件:

  • poi-3.9.jar
  • poi-ooxml-3.9.jar
  • poi-ooxml-schemas-3.7.jar
  • xmlbeans-2.3.0.jar
  • dom4j-1.6.1.jar

关于java - 如何使用 poi 在 java 中读取 excel(.xlsx)?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/16357812/

相关文章:

java - poi jar 文件 java.lang.NoSuchMethodError 问题

java - 正则表达式过滤所有内部括号表达式

java - 如何使用 Selenium 和 Java 在 https ://www. phptravels.net/website 中提取 HTML5 约束验证的文本?

java - 为什么 @ResponseBody 返回已排序的 LinkedHashMap 未排序?

java - 包含日期的单元格上的 DataFormatter 呈现两位数年份

java - 为什么 Apache poi 的 Workbook.close() 方法将内容写入输入文件?

java - 在 Jenkins 中运行 Windows Batch Commando 时出错,但在 CMD 中运行正常

java - 编辑 Gradle 后超出 GC 开销限制?

java - Apache POI XSLFSlide 页码

c# - NPOI,XSSFComment c# : Unable to set Background color for the comment