Java使用POI导出Excel、合并单元格、插入网络图片

该博客介绍了如何在Excel中通过Java代码实现网络图片的插入,并使图片自适应单元格大小。提供了insertImage方法用于插入图片,并展示了如何在循环中为每个观众插入对应的座位图片。此外,还展示了如何根据观众的座位和校核记录动态调整插入行数。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

假设存在这样一张表A (audience),观众表
id,zjhm,name,gender,address
表B(seat),座位表,表明这个观众主动坐过哪些座位
id,
表C(check),校核表,表明这个观众被系统管理人员校核过哪些座位
id

一、插入网络图片并自适应

Excel中插入图片方法
参数1: 工作薄
参数2: 工作表名
参数3: 网络图片地址
参数4: 图片插入到哪一行
参数5: 图片插入到哪一列

    public static void insertImage(XSSFWorkbook workbook, String sheetName,String imageUrl,
                                   int row,int col) {
        try {
            URL url = new URL(imageUrl);
            HttpURLConnection conn = (HttpURLConnection) url.openConnection();
            conn.setRequestMethod("GET");
            conn.setConnectTimeout(5000);
            InputStream inputStream = conn.getInputStream();
            XSSFSheet sheet = workbook.getSheet(sheetName);
            XSSFDrawing patriarch = sheet.createDrawingPatriarch();
            XSSFClientAnchor anchor = new XSSFClientAnchor(0,0,255,255,
                    col,row,col+1,row+1);
            // 图片自适应单元格大小
            anchor.setAnchorType(AnchorType.byId(0));
            patriarch.createPicture(anchor,workbook.addPicture(inputStream,XSSFWorkbook.PICTURE_TYPE_WPG));
        } catch (Exception e) {
            e.printStackTrace();
        }
    }

调用

		int startRowIndex = 2;
        int endRowIndex = 1;
        for (Audience audience : audienceList) {
            int checkSize = audience.getCheckList().size();
            int seatSize = audience.getSeatList().size();
            if (checkSize >= seatSize) {
                endRowIndex += checkSize;
            } else {
                endRowIndex += seatSize;
            }
            for (int i = 0; i < aliPersonFace.getSeatList().size(); i++) {
                AliPersonFace child = aliPersonFace.getSeatList().get(i);
                ExcelUtil.insertImage(xssfWorkbook, sheetName, child.getImageUrl(), startRowIndex + i, 10);
            }
            startRowIndex = endRowIndex + 1;
        }

待加:

  • 单元格合并居中
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值