Ошибка компиляции Apache POI 4.0.0 в CellType - PullRequest
0 голосов
/ 21 сентября 2018

Компиляция завершается с этой ошибкой:

cannot find symbol
case FORMULA:
symbol: variable FORMULA

Та же ошибка возникает в следующих случаях.

Я использую Apache POI 4.0.0 с Java 8.

Мой код:

try (Workbook wb = WorkbookFactory.create(inputStream)) {
    Sheet sheet = wb.getSheetAt(0);
        for (Row row : sheet) {
            for (Cell cell : row) {
                switch (cell.getCellType()) {
                    case FORMULA:
                        [code]
                        break;
                }
            }
        }
}

Примечание 1: развертывание на локальном GlassFish 4.1.2 из NetBeans 8.2 работает, но сборка завершается неудачей.

Примечание 2: Если я заменю «getCellType» на «getCellTypeEnum "(устарело), ​​сборка завершается без ошибок.

Версии:

  • Java 1.8u172 (i586) / затем Java 1.8u181 (i586)
  • poi-4.0.0
  • poi-ooxml-4.0.0
  • poi-ooxml-schemas-4.0.0
  • xmlbeans-3.0.1
  • commons-codec-1.11
  • commons-collection4-4.2
  • commons-logging-1.2
  • commons-math3-3.6.1
  • jsf-api-2.2.15
  • jsf-impl-2.2.15
  • primefaces-6.2.6

Полный код

POIUtils.java

package fr.mycompany.config.files;

import fr.mycompany.config.exception.MyAppException;
import java.io.IOException;
import java.io.InputStream;
import java.time.LocalDate;
import java.time.ZoneId;
import java.time.format.DateTimeFormatter;
import java.util.ArrayList;
import java.util.List;
import java.util.Locale;
import javax.faces.application.FacesMessage;
import org.apache.poi.EncryptedDocumentException;
import org.apache.poi.ss.usermodel.Cell;
import org.apache.poi.ss.usermodel.DataFormatter;
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.ss.usermodel.WorkbookFactory;
import org.apache.poi.ss.usermodel.CellType;

public class POIUtils {

    public static List<List<String>> parseExcelFile(InputStream is) throws MyAppException {

        List<List<String>> lines = new ArrayList<>();

        try (Workbook wb = WorkbookFactory.create(is)) {
            Sheet sheet = wb.getSheetAt(0);
            DataFormatter df = new DataFormatter(true);
            int numRow = 0;
            for (Row row : sheet) {
                int numCol = 0;
                List<String> currentLine = new ArrayList<>();
                for (Cell cell : row) {
                    switch (cell.getCellType()) {
                        case FORMULA:
                            currentLine.add(numCol, "");
                            break;
                        case NUMERIC:
                            if (DateUtil.isCellDateFormatted(cell)) {
                                LocalDate ld = cell.getDateCellValue().toInstant().atZone(ZoneId.systemDefault()).toLocalDate();
                                String frLocalDate = ld.format(DateTimeFormatter.ofPattern("dd/MM/yyyy", Locale.FRANCE));
                                currentLine.add(numCol, frLocalDate);
                            } else {
                                String cellValue = df.formatCellValue(cell);
                                currentLine.add(numCol, cellValue);
                            }
                            break;
                        default:
                            String cellValue = df.formatCellValue(cell);
                            currentLine.add(numCol, cellValue);
                            break;
                    }
                    numCol++;
                }
                while (row.getRowNum() > numRow) {
                    lines.add(new ArrayList<>());
                    numRow++;
                }
                lines.add(row.getRowNum(), currentLine);
                numRow++;
            }
            if (lines.isEmpty()) {
                throw new MyAppException(FacesMessage.SEVERITY_WARN, "Le fichier est vide.");
            }
        } catch (IOException ex) {
            throw new MyAppException(FacesMessage.SEVERITY_FATAL, "Une erreur est survenue lors du traitement du fichier.", ex);
        } catch (EncryptedDocumentException ex) {
            throw new MyAppException(FacesMessage.SEVERITY_FATAL, "Le fichier est protégé par un mot de passe et n'a pas pu être lu.", ex);
        }

        return lines;

    }    

}

FileImportBean.java

package fr.mycompany.coordination;

import fr.mycompany.config.exception.MyAppException;
import fr.mycompany.config.files.POIUtils;
import java.io.Serializable;
import java.io.IOException;
import javax.faces.application.FacesMessage;
import javax.inject.Named;
import javax.faces.view.ViewScoped;
import java.util.List;
import java.util.ArrayList;
import org.apache.poi.poifs.filesystem.FileMagic;
import org.primefaces.event.FileUploadEvent;
import org.primefaces.event.UploadedFile;

@Named
@ViewScoped
public class FileImportBean implements Serializable {

    private transient UploadedFile file;
    private List<List<String>> parsedContent = new ArrayList<>();

    public void handleFileUpload (FileUploadEvent event) {
        try {
            file = event.getFile();
            if (null != file) {
                switch (FileMagic.valueOf(FileMagic.prepareToCheckMagic(file.getInputstream()))) {
                    case OOXML:
                        parsedContent = POIUtils.parseExcelFile(file.getInputstream());
                        break;
                    default:
                        (new MyAppException(FacesMessage.SEVERITY_ERROR, "Type de fichier non géré.", ex)).doFacesMessage();
                        break;
                }
            } else {
            }
        } catch (IOException ex) {
            (new MyAppException(FacesMessage.SEVERITY_FATAL, "Une erreur est survenue lors du traitement du fichier.", ex)).doFacesMessage();
        } catch (MyAppException ex) {
            ex.doFacesMessage();
        }
    }

}

fileImport.xhtml

<h:form enctype="multipart/form-data">
    <p:messages showDetail="true" />
    <p:fileUpload
        mode="advanced"
        skinSimple="true"
        auto="true"
        multiple="false"
        required="true"
        update="@form"
        fileUploadListener="#{fileImportBean.handleFileUpload}"
</h:form>

1 Ответ

0 голосов
/ 21 сентября 2018

Благодаря идее, предложенной @AxelRichter в разделе комментариев, я обнаружил, что включил JAR (сделанный моим коллегой), используя более старую версию POI (3.15).Я обновил этот до 4.0.0 тоже и вуаля!По крайней мере, я кое-что узнал сегодня ... Спасибо!

...