木成洲 2016-08-21 18:08 采纳率: 0%
浏览 2791

java中使用poi操作excel时,不明白这个为什么无法写入

在使用poi包进行操作excel的时候,出现在两次for循环中,无法正确写入excel现象

        XSSFWorkbook wb = new XSSFWorkbook();
        Sheet sheet = wb.createSheet("result");
        for (int i = 0;i< 79;i++){
            for(int j= 1;j<4;j++){
                sheet.createRow(i).createCell(0).setCellValue("当前i:"+i);
                sheet.createRow(i).createCell(j).setCellValue("当前j:"+j);
            }
        }

        FileOutputStream fos = null;
        try {  
            fos = new FileOutputStream(McUtils.compareResult_str + "C666.xlsx");  
            wb.write(fos);        
        } catch (IOException e) {  
            System.out.println(e.toString());  
        } finally {  
            try {  
                fos.close();  
            } catch (IOException e) {  
                System.out.println(e.toString());  
            }  
        }  

生成后的文档

1、是不能用两次for循环,还是其他原因?
2、for循环中有两句setValue,但是只有后一句生效了,并且后一句只写入了最后一列(即只有j=3的时候生效了),这是什么原因

  • 写回答

3条回答

  • qq_20992735 2016-08-22 00:05
    关注

    sheet.createRow(i).createCell(0).setCellValue("当前i:"+i);每次外循环执行了三次这条语句
    导致每一行创建了三次第一个单元格(就是表格的A列被创建了三次)

    评论

报告相同问题?

悬赏问题

  • ¥50 comfyui下连接animatediff节点生成视频质量非常差的原因
  • ¥20 有关区间dp的问题求解
  • ¥15 多电路系统共用电源的串扰问题
  • ¥15 slam rangenet++配置
  • ¥15 有没有研究水声通信方面的帮我改俩matlab代码
  • ¥15 ubuntu子系统密码忘记
  • ¥15 信号傅里叶变换在matlab上遇到的小问题请求帮助
  • ¥15 保护模式-系统加载-段寄存器
  • ¥15 电脑桌面设定一个区域禁止鼠标操作
  • ¥15 求NPF226060磁芯的详细资料