POIXMLException во время попытки записи книги apache poi - PullRequest
0 голосов
/ 03 октября 2018

Предполагается, что приведенный ниже код является копией файла Excel Pristine Copy (файл .xlsx).Имя копии - copyTest.Копия сделана, и когда я открываю ее вручную, файл Excel имеет содержимое, как и ожидалось.Однако, когда я пытаюсь открыть новый файл в коде и записать его, он выдает ошибку.

public static void main(String[] args)throws IOException, InvalidFormatException {

    String fileLocation = "C:\\Users\\someUser\\Documents\\Project Docs\\Pristine Copy.xlsx";
    String newFileLocation = "C:\\Users\\someUser\\Documents\\Project Docs\\copyTest.xlsx";

    Path source = Paths.get(fileLocation);
    Path dest = Paths.get(newFileLocation);
    Files.copy(source, dest, StandardCopyOption.REPLACE_EXISTING);



    Workbook newWorkbook = WorkbookFactory.create(new File(newFileLocation));   
    System.out.println("There are "+newWorkbook.getNumberOfSheets()+" sheets.");

    MongoTest mt = new MongoTest(); 
    Document doc = mt.fetchRecord("HD123456", "SSE");
    Sheet sheet = newWorkbook.getSheet("SSE");
    writeToSheet(sheet, doc);

    FileOutputStream out = new FileOutputStream(newFileLocation);
    newWorkbook.write(out);
    out.close();
    System.out.println("Check");
    newWorkbook.close();

}

Трассировка стека приведена ниже:

Exception in thread "main" org.apache.poi.POIXMLException: java.lang.NullPointerException
    at org.apache.poi.POIXMLDocument.getProperties(POIXMLDocument.java:147)
    at org.apache.poi.POIXMLDocument.write(POIXMLDocument.java:225)
    at com.cerner.excelTest.ExcelFile.main(ExcelFile.java:63)
Caused by: java.lang.NullPointerException
    at org.apache.poi.openxml4j.util.ZipSecureFile$ThresholdInputStream.read(ZipSecureFile.java:211)
    at com.sun.org.apache.xerces.internal.impl.XMLEntityManager$RewindableInputStream.read(Unknown Source)
    at com.sun.org.apache.xerces.internal.impl.XMLEntityManager.setupCurrentEntity(Unknown Source)
    at com.sun.org.apache.xerces.internal.impl.XMLVersionDetector.determineDocVersion(Unknown Source)
    at com.sun.org.apache.xerces.internal.parsers.XML11Configuration.parse(Unknown Source)
    at com.sun.org.apache.xerces.internal.parsers.XML11Configuration.parse(Unknown Source)
    at com.sun.org.apache.xerces.internal.parsers.XMLParser.parse(Unknown Source)
    at com.sun.org.apache.xerces.internal.parsers.DOMParser.parse(Unknown Source)
    at com.sun.org.apache.xerces.internal.jaxp.DocumentBuilderImpl.parse(Unknown Source)
    at javax.xml.parsers.DocumentBuilder.parse(Unknown Source)
    at org.apache.poi.util.DocumentHelper.readDocument(DocumentHelper.java:140)
    at org.apache.poi.POIXMLTypeLoader.parse(POIXMLTypeLoader.java:163)
    at org.openxmlformats.schemas.officeDocument.x2006.extendedProperties.PropertiesDocument$Factory.parse(Unknown Source)
    at org.apache.poi.POIXMLProperties.<init>(POIXMLProperties.java:78)
    at org.apache.poi.POIXMLDocument.getProperties(POIXMLDocument.java:145)
    ... 2 more

проблема возникает только тогда, когда я пытаюсь открыть файл, чтобы записать в него изменения рабочей книги (последние несколько строк).Остальная часть кода работает нормально, без каких-либо проблем.Есть идеи, в чем проблема?(Я использую Apache POI версии 3.17)

...