Apache Poi 4.0.0 Ошибка компиляции на CellypeJAVA

Программисты JAVA общаются здесь
Anonymous
Apache Poi 4.0.0 Ошибка компиляции на Cellype

Сообщение Anonymous »

Компиляция не удается с этой ошибкой: < /p>

cannot find symbol
case FORMULA:
symbol: variable FORMULA
< /code>

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

Я использую Apache Poi 4.0.0 с Java 8 . < /p>

Мой код: < /p>

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

Код: Выделить всё

break;
}
}
}
}
< /code>

Примечание 1: развертывание на локальных стеклянных рыбах 4.1.2 из Netbeans 8.2 работает, но строительство сбой. < /p>

Примечание 2: если я заменяю «getCellType» на «getCelltyPeenum» (устарел), сборка заполняется без ошибки.  < /P>

версии: < /p>


[*] java 1.8u172 (i586) /then java 1.8u181 (i586) < /li>
poi-44 > poi-ooxml-4.0.0
[*]poi-ooxml-schemas-4.0.0.0
[*]xmlbeans-3.0.1
[*]commons-codec-1.11
[*]commons-collections4-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 < /li>
< /ul>

 Полный код < /h1>

< h3> poiutils.java < /h3>

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 parseExcelFile(InputStream is) throws MyAppException {

List 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 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;

}

}
< /code>

 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 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();
}
}

}
< /code>

 fileimport.xhtml





Подробнее здесь: [url]https://stackoverflow.com/questions/52439572/apache-poi-4-0-0-compilation-error-on-celltype[/url]

Вернуться в «JAVA»