У меня есть Java-код, в котором я создаю новый файл .xlsm, который я создаю, отражая формат другого пустого файла .xlsm. Моя проблема, когда я устанавливаю формулу в определенной ячейке на этом новом .xlsm создан. Когда я открываю файл, в ячейке отображается: #NAME ?. Но когда я нажимаю клавишу ввода в ячейке, формула отображается правильно. И когда я выхожу, формула работает.
Почему это происходит?
Java-код указан ниже:
public static String main(String[] args) throws Exception {
Class.forName("com.mysql.jdbc.Driver");
Connection connect = DriverManager.getConnection(
"jdbc:mysql://localhost:3306/database" ,
"user" ,
"password"
);
Statement statement = connect.createStatement();
ResultSet resultSet = statement.executeQuery("select * from `table`");
FileInputStream file = new FileInputStream(new File("C:\\Users\\Desktop\\Folder1.xlsm"));
XSSFWorkbook wb = new XSSFWorkbook(OPCPackage.open(file));
XSSFSheet spreadsheet = wb.getSheet("Planilha1");
XSSFRow row = spreadsheet.createRow(1);
XSSFCell cell;
int i = 1;
while(resultSet.next()) {
row = spreadsheet.createRow(i);
cell = row.createCell(1);
cell.setCellValue("");
cell = row.createCell(2);
cell.setCellValue(resultSet.getString("column1"));
i++;
}
XSSFRow linhacontador = spreadsheet.getRow(1);
if (linhacontador == null) {
linhacontador = spreadsheet.createRow(1);
}
XSSFCell colunacontador = linhacontador.getCell(34);
if (colunacontador == null) {
colunacontador = linhacontador.createCell(34);
}
colunacontador.setCellType(XSSFCell.CELL_TYPE_FORMULA);
colunacontador.setCellFormula("CONT.SE(AH:AH, \"<>\")");
CellRangeAddress range = new CellRangeAddress(1, i-1, 25, 25);
spreadsheet.addMergedRegion(range);
FileOutputStream out = new FileOutputStream(new File("C:\\Users\\Desktop\\exceldatabase.xlsm"));
wb.write(out);
out.close();
connect.close();
return "Worksheet Done!";
}
Видимо, моя проблема здесь:
colunacontador.setCellType(XSSFCell.CELL_TYPE_FORMULA);
colunacontador.setCellFormula("CONT.SE(AH:AH, \"<>\")");