Updating excel file using Apache POI

前端 未结 3 714
傲寒
傲寒 2021-02-07 08:34

I am trying to update an existing excel file using Apache POI. Every time I run my code I receive an error as shown below. I have also tried FileInputStreamNewFile thing.

<
3条回答
  •  悲&欢浪女
    2021-02-07 09:00

    Thanks Jelle Heuzel for getting a good example.
    I just wanted to add the resulting working code so other can incorporate it in their code faster.

    I also had to use XSSFRow instead of HSSFRow but other than that it works fine for me.

    package stackoverflow.appachePOI;
    
    import java.io.File;
    import java.io.FileInputStream;
    import java.io.FileNotFoundException;
    import java.io.FileOutputStream;
    import java.io.IOException;
    
    import org.apache.poi.ss.usermodel.Cell;
    import org.apache.poi.xssf.usermodel.XSSFRow;
    import org.apache.poi.xssf.usermodel.XSSFSheet;
    import org.apache.poi.xssf.usermodel.XSSFWorkbook;
    
    public class WriteExcelTest {
    
        public static void writeXLSXFile(int row, int col) throws IOException {
            try {
                FileInputStream file = new FileInputStream("C:\\Users\\Sam\\files\\Masterproef lca\\lca-analysebeheer\\Test-Files\\exceltemplates\\template.xlsx");
    
                XSSFWorkbook workbook = new XSSFWorkbook(file);
                XSSFSheet sheet = workbook.getSheetAt(0);
                Cell cell = null;
    
                //Retrieve the row and check for null
                XSSFRow sheetrow = sheet.getRow(row);
                if(sheetrow == null){
                    sheetrow = sheet.createRow(row);
                }
                //Update the value of cell
                cell = sheetrow.getCell(col);
                if(cell == null){
                    cell = sheetrow.createCell(col);
                }
                cell.setCellValue("Pass");
    
                file.close();
    
                FileOutputStream outFile =new FileOutputStream(new File("C:\\Users\\Sam\\files\\Masterproef lca\\lca-analysebeheer\\Test-Files\\exceltemplates\\Output.xlsx"));
                workbook.write(outFile);
                outFile.close();
    
            } catch (FileNotFoundException e) {
                e.printStackTrace();
            } catch (IOException e) {
                e.printStackTrace();
            }
        }
    
        public static void main(String[] args) throws IOException {
            // TODO Auto-generated method stub
            writeXLSXFile(3, 3);
        }
    
    }
    

提交回复
热议问题