java excel 操作_JAVA-Excel文件操作

importjava.io.File;importjava.io.FileInputStream;importjava.io.FileOutputStream;importjava.io.IOException;importjava.text.SimpleDateFormat;importjava.util.HashMap;importjava.util.Map;importjavax.swing.JOptionPane;importorg.apache.poi.EncryptedDocumentException;importorg.apache.poi.openxml4j.exceptions.InvalidFormatException;importorg.apache.poi.ss.usermodel.Row;importorg.apache.poi.ss.usermodel.Sheet;importorg.apache.poi.ss.usermodel.Workbook;importorg.apache.poi.ss.usermodel.WorkbookFactory;importorg.apache.poi.xssf.usermodel.XSSFWorkbook;public classExcelLog {public ExcelLog(intindex) {

createNewBook();

}//新建工作表

private voidcreateNewBook() {try{

String path= "D:\\test.xlsx";

File f= newFile(path);

File dir=f.getParentFile();if (!dir.exists()) {//如果文件路径不存在,则创建路径

dir.mkdirs();

}if (!f.exists()) {//如果文件不存在,则新建文件

Workbook wb = new XSSFWorkbook(); //.xlsx

Sheet sheet = wb.createSheet("Test Log"); //新建Sheet

Row row = sheet.createRow(0); //写一行数据

String[] header = {"COL1", "COL2", "COL3", "COL4", "COL5"};for (int i = 0; i < header.length; i++) {

row.createCell(i).setCellValue(header[i]);

}//写入文件

try (FileOutputStream fileOut = newFileOutputStream(path)) {

wb.write(fileOut);

wb.close();

}

}

}catch(IOException ex) {

JOptionPane.showMessageDialog(null, "无法写入Excel文件:" +ex.getMessage());

System.exit(-1);

}

}//Sheet表的行数

private intgetRowCount() {try (FileInputStream fileInput = newFileInputStream(path)) {

Workbook wb=WorkbookFactory.create(fileInput);

Sheet sheet= wb.getSheetAt(0);returnsheet.getPhysicalNumberOfRows();

}catch (IOException | InvalidFormatException |EncryptedDocumentException ex) {

JOptionPane.showMessageDialog(null, "无法读取Excel文件:" +ex.getMessage());

System.exit(-1);return 0;

}

}//写一行数据

private voidwriteLine(String[] items) {try{

Workbook wb= WorkbookFactory.create(newFileInputStream(path));

Sheet sheet= wb.getSheetAt(0);int rowIndex = this.getRowCount();

Row row=sheet.createRow(rowIndex);for (int i = 0; i < items.length; i++) {

row.createCell(i).setCellValue(items[i]);

}//写入文件

try(FileOutputStream fileOut = newFileOutputStream(path);){

wb.write(fileOut);

}

wb.close();

}catch (IOException | InvalidFormatException |EncryptedDocumentException ex) {

ex.printStackTrace();

JOptionPane.showMessageDialog(null, "无法写入Excel文件:" +ex.getMessage());

System.exit(-1);

}

}

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值