簡體   English   中英

無法使用poi api將xlsx轉換為csv

[英]can not convert xlsx to csv using poi api

我正在嘗試使用以下代碼將xlsx文件轉換為csv文件

import java.io.*;
import java.util.Iterator;
import org.apache.poi.ss.usermodel.Cell;
import org.apache.poi.ss.usermodel.Row;
import org.apache.poi.xssf.usermodel.XSSFSheet;
import org.apache.poi.xssf.usermodel.XSSFWorkbook;

public class XLStoCSVConvert {

     static void xlsx(File inputFile, File outputFile) {
            // For storing data into CSV files
            StringBuffer data = new StringBuffer();

            try {
                FileOutputStream fos = new FileOutputStream(outputFile);
                // Get the workbook object for XLSX file
                System.out.println("working......1");
                XSSFWorkbook wBook = new XSSFWorkbook(new FileInputStream(inputFile));
                // Get first sheet from the workbook
                System.out.println("working......2");
                XSSFSheet sheet = wBook.getSheetAt(0);
                Row row;
                Cell cell;
                // Iterate through each rows from first sheet
                Iterator<Row> rowIterator = sheet.iterator();

                while (rowIterator.hasNext()) {
                    row = rowIterator.next();

                    // For each row, iterate through each columns
                    Iterator<Cell> cellIterator = row.cellIterator();
                    while (cellIterator.hasNext()) {

                        cell = cellIterator.next();

                        switch (cell.getCellType()) {
                            case Cell.CELL_TYPE_BOOLEAN:
                                data.append(cell.getBooleanCellValue() + ",");

                                break;
                            case Cell.CELL_TYPE_NUMERIC:
                                data.append(cell.getNumericCellValue() + ",");

                                break;
                            case Cell.CELL_TYPE_STRING:
                                data.append(cell.getStringCellValue() + ",");
                                break;

                            case Cell.CELL_TYPE_BLANK:
                                data.append("" + ",");
                                break;
                            default:
                                data.append(cell + ",");

                        }
                    }
                }

                fos.write(data.toString().getBytes());
                fos.close();

            } catch (Exception ioe) {
                ioe.printStackTrace();
            }
        }

    public static void main(String[] args) {
        File inputFile = new File("/home/raptorjd4/Desktop/ToConsult.xlsx");
        //writing excel data to csv 
        File outputFile = new File("/home/raptorjd4/Desktop/RaptorTrackingSystem/ToConsult.csv");
        xlsx(inputFile, outputFile);

    }

}

但是我正在得到輸出,

工作中...... 1 Exception in thread "main" java.lang.NoClassDefFoundError: org/apache/poi/UnsupportedFileFormatException

我的jar在lib文件夾中,

poi-3.5-FINAL.jar

poi-ooxml-3.11.jar

為什么當我在lib文件夾中映射所有需要的jar文件時出現此錯誤。

我在哪里做錯了?

對我來說,您的代碼工作得很好,以下是我添加的依賴項:-

在此處輸入圖片說明

問題可能出在Excel中的數據還是缺少一些依賴項。
確保您確實對類路徑具有所有必要的依賴關系。

您的問題是這部分:

  • poi-3.5-FINAL.jar

  • poi-ooxml-3.11.jar

本Apache POI常見問題解答條目所述

我可以混合不同版本的POI罐子嗎?

否。不支持此功能。

所有使用中的POI罐子必須來自同一版本。 不支持諸如poi-3.11.jar和poi-ooxml-3.9.jar之類的組合,它們將無法以不可預測的方式工作。

必須確保所有Apache POI jar都來自相同版本!

將您的jar切換為相同版本,最好是最新版本,您應該會做得很好

我通過添加以下jar文件解決了這個問題,

poi-3.9.jar

poi-ooxml-3.9.jar

poi-ooxml-schemas-3.9-20121203.jar

xmlbeans-2.3.0.jar

dom4j-1.6.1.jar

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM