poi读取excel模板,填充内容,添加图片并导出

1 篇文章 0 订阅
public FileOutputStream illustrate() {
    FileOutputStream fileOut = null;
    BufferedImage bufferImg = null;
    try {
        ByteArrayOutputStream byteArrayOut = new ByteArrayOutputStream();
        //加载图片
        bufferImg = ImageIO.read(new File(E:/));
        ImageIO.write(bufferImg, "png", byteArrayOut);
        HSSFWorkbook wb = getWorkbook();
        HSSFSheet sheet = wb.getSheetAt(0);
        HSSFPatriarch patriarch = sheet.createDrawingPatriarch();
        /**
         dx1 - the x coordinate within the first cell.//定义了图片在第一个cell内的偏移x坐标,既左上角所在cell的偏移x坐标,一般可设0
         dy1 - the y coordinate within the first cell.//定义了图片在第一个cell的偏移y坐标,既左上角所在cell的偏移y坐标,一般可设0
         dx2 - the x coordinate within the second cell.//定义了图片在第二个cell的偏移x坐标,既右下角所在cell的偏移x坐标,一般可设0
         dy2 - the y coordinate within the second cell.//定义了图片在第二个cell的偏移y坐标,既右下角所在cell的偏移y坐标,一般可设0
         col1 - the column (0 based) of the first cell.//第一个cell所在列,既图片左上角所在列
         row1 - the row (0 based) of the first cell.//图片左上角所在行
         col2 - the column (0 based) of the second cell.//图片右下角所在列
         row2 - the row (0 based) of the second cell.//图片右下角所在行
         */
        HSSFClientAnchor anchor = new HSSFClientAnchor(0, 0, 0, 0,(short) 2, 2, (short) 2, 8);
        //插入图片
        patriarch.createPicture(anchor, wb.addPicture(byteArrayOut.toByteArray(), HSSFWorkbook.PICTURE_TYPE_PNG));

        // 如果文件夹不存在则创建
        File pathfile = new File(fileUrl+"/download");
        if (!pathfile.exists()) {
            pathfile.mkdirs();
        }

        fileOut = new FileOutputStream(fileUrl+"download/excel.xls");
        // 输出文件
        wb.write(fileOut);
    } catch (Exception e) {
        e.printStackTrace();
    }
    return fileOut;
}
  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值