创建新的xlsx文件时,我遇到了XSSFWorkbook apis的问题。
场景:我的gui菜单中有一个菜单项“New File”,它从流中创建新的xlsx文件。第一次单击菜单项“新建文件”,然后出现文件新对话框,我给出了新的xlsx文件的名称,并创建了新文件。但是当我第二次点击这个菜单项“新文件”时,新的xlsx就不会被创建了。
//Code snippet
File newOpenXLSFile;
public XSSFWorkbook newPtrIrWorkBook;
newPtrIrStream = this.getClass().getResourceAsStream ("/org/ama/defect/prevention/templates/MainTemplate.xlsx");
private void jMenuItem1ActionPerformed(java.awt.event.ActionEvent evt) {
// TODO add your handling code here:
logger.debug("You choose to create new PTR/IR file");
int returnVal = jFileChooser4.showDialog(this, "New PTR/IR Data File");
if (returnVal == JFileChooser.APPROVE_OPTION) {
newOpenXLSFile = jFileChooser4.getSelectedFile();
logger.debug("file path " + newOpenXLSFile);
try {
logger.debug("For second time, I am stopped here:");
//newPtrIrWorkBook = new HSSFWorkbook(newPtrIrPFS, true); //copying extract into Excel file
newPtrIrWorkBook = new XSSFWorkbook(newPtrIrStream);
logger.debug("New File..." + newOpenXLSFile.getPath());
FileOutputStream out = new FileOutputStream(newOpenXLSFile);
newPtrIrWorkBook.write(out);
out.close();
} catch (Exception e) {
e.getMessage();
}
} else {
logger.debug("New file dialogue cancelled by user.");
}
}
第二次,我想它会在代码声明中阻止:
logger.debug("For second time, I am stopped here:");
//newPtrIrWorkBook = new HSSFWorkbook(newPtrIrPFS, true);//copying extract into
//Excel file
---> newPtrIrWorkBook = new XSSFWorkbook(newPtrIrStream); <---
调试日志:
2011-08-18 13:04:37,602 [AWT-EventQueue-0] DEBUG org.ama.defect.prevention.tool.gui.GUI.class - You choose to create new PTR/IR file
2011-08-18 13:04:45,586 [AWT-EventQueue-0] DEBUG org.ama.defect.prevention.tool.gui.GUI.class - file path C:\Documents and Settings\rmehta\Desktop\Try\FirstFile.xlsx
2011-08-18 13:04:45,586 [AWT-EventQueue-0] DEBUG org.ama.defect.prevention.tool.gui.GUI.class - For second time, I am stopped here:
2011-08-18 13:04:46,351 [AWT-EventQueue-0] DEBUG org.ama.defect.prevention.tool.gui.GUI.class - New File...C:\Documents and Settings\rmehta\Desktop\Try\FirstFile.xlsx
2011-08-18 13:04:52,898 [AWT-EventQueue-0] DEBUG org.ama.defect.prevention.tool.gui.GUI.class - You choose to create new PTR/IR file
2011-08-18 13:04:57,116 [AWT-EventQueue-0] DEBUG org.ama.defect.prevention.tool.gui.GUI.class - file path C:\Documents and Settings\rmehta\Desktop\Try\SecondFile.xlsx
2011-08-18 13:04:57,116 [AWT-EventQueue-0] DEBUG org.ama.defect.prevention.tool.gui.GUI.class - For second time, I am stopped here:
你能帮我解决这个问题吗?但是,HSSFWorkbook
(对于xls文件)没问题。
非常感谢,
的Rahul
答案 0 :(得分:1)
使用调试器识别问题:
java.io.IOException: Stream closed
似乎问题是:stream只能读取一次,第二次尝试读取会导致此IOException。
所以为了解决这个问题,我把
newPtrIrStream = this.getClass()
.getResourceAsStream("/org/ama/defect/prevention/templates/MainTemplate.xlsx");
在jMenuItem1ActionPerformed
内,问题已解决。