noa*_*oai 2 java excel date apache-poi
我正在尝试使用Apache的Java POI将日期添加到电子表格中。但是,我最后将日期格式的单元格中的日期不被该单元格识别为日期,而是将其识别为字符串。但是,当我随后打开电子表格时,只需单击一下即可(例如,在没有进行有效更改的情况下对其进行编辑),并且可以自动识别日期格式。如何让我的程序执行最后一步而无需干预?提前非常感谢您!
CreationHelper creationHelper = wb.getCreationHelper();
XSSFCellStyle cellStyleDate = wb.createCellStyle();
LocalDate start = LocalDate.of(2000, 1, 1);
LocalDate end = LocalDate.of(2000, 12, 31);
cellStyleDate.setDataFormat(creationHelper.createDataFormat().getFormat("dd.mm.yyyy"));
int i = 1;
for (LocalDate date = start; date.isBefore(end); date = date.plusDays(1)) {
// wb.getSheetAt(0).createRow(i).createCell(0).setCellValue(date);
wb.getSheetAt(0).createRow(i).createCell(0).setCellValue(date.toString());
// wb.getSheetAt(0).createRow(i).createCell(0).setCellValue(date.getDayOfMonth() + "." + date.getMonthValue() + "." + date.getYear());
wb.getSheetAt(0).getRow(i).getCell(0).setCellStyle(cellStyleDate);
i++;
}
Run Code Online (Sandbox Code Playgroud)
截至本文记录,有两种可能的方法来设置日期值。 setCellValue(java.util.Calendar value)和setCellValue(java.util.Date value)。java.time.LocalDate到目前为止,尚不支持使用。
因此,必须先将LocalDate转换为,java.util.Date然后才能设置为单元格值。
例:
import java.io.*;
import org.apache.poi.ss.usermodel.*;
import org.apache.poi.xssf.usermodel.XSSFWorkbook;
import java.util.Date;
import java.time.LocalDate;
import java.time.ZoneId;
import java.awt.Desktop;
class LocalDateTest {
public static void main(String[] args) {
try {
Workbook wb = new XSSFWorkbook();
Sheet sheet = wb.createSheet("Sheet1");
CreationHelper creationHelper = wb.getCreationHelper();
CellStyle cellStyleDate = wb.createCellStyle();
LocalDate start = LocalDate.of(2000, 1, 1);
LocalDate end = LocalDate.of(2000, 12, 31);
cellStyleDate.setDataFormat(creationHelper.createDataFormat().getFormat("dd.mm.yyyy"));
int i = 1;
for (LocalDate localdate = start; localdate.isBefore(end.plusDays(1)); localdate = localdate.plusDays(1)) {
Date date = Date.from(localdate.atStartOfDay(ZoneId.systemDefault()).toInstant());
wb.getSheetAt(0).createRow(i).createCell(0).setCellValue(date);
wb.getSheetAt(0).getRow(i).getCell(0).setCellStyle(cellStyleDate);
i++;
}
OutputStream out = new FileOutputStream("LocalDateTest.xlsx");
wb.write(out);
wb.close();
System.out.println("Done");
File outputfile = new File("LocalDateTest.xlsx");
Desktop.getDesktop().open(outputfile);
} catch (FileNotFoundException fnfex) {
} catch (IOException ioex) {
}
}
}
Run Code Online (Sandbox Code Playgroud)