返回顶部

poi在excel中插入图片

复制代码
public static void main(String[] args) {
        FileOutputStream fileOut = null;
        BufferedImage bufferImg = null;
        //先把读进来的图片放到一个ByteArrayOutputStream中,以便产生ByteArray
        try {
            ByteArrayOutputStream byteArrayOut = new ByteArrayOutputStream();
            bufferImg = ImageIO.read(new File("D:/device_gps.jpg"));
            ImageIO.write(bufferImg, "jpg", byteArrayOut);

            XSSFWorkbook wb1 = new XSSFWorkbook();
            XSSFSheet sheet1 = wb1.createSheet("test picture");
            //画图的顶级管理器,一个sheet只能获取一个(一定要注意这点)
            XSSFDrawing patriarch = sheet1.createDrawingPatriarch();
            //anchor主要用于设置图片的属性

            /**
             * @param dx1 图片的左上角在开始单元格(col1,row1)中的横坐标
             * @param dy1 图片的左上角在开始单元格(col1,row1)中的纵坐标
             * @param dx2 图片的右下角在结束单元格(col2,row2)中的横坐标
             * @param dy2 图片的右下角在结束单元格(col2,row2)中的纵坐标
             * @param col1 开始单元格所处的列号, base 0, 图片左上角在开始单元格内
             * @param row1 开始单元格所处的行号, base 0, 图片左上角在开始单元格内
             * @param col2 结束单元格所处的列号, base 0, 图片右下角在结束单元格内
             * @param row2 结束单元格所处的行号, base 0, 图片右下角在结束单元格内
             */
            //XSSFClientAnchor anchor = new XSSFClientAnchor(dx1, dy1, dx2, dy2,(short) col1, row1, (short) col2, row2);
            XSSFClientAnchor anchor = new XSSFClientAnchor(0, 0, 255, 255,(short) 1, 1, (short) 5, 8);
            anchor.setAnchorType(ClientAnchor.AnchorType.DONT_MOVE_AND_RESIZE);
            //插入图片
            patriarch.createPicture(anchor, wb1.addPicture(byteArrayOut.toByteArray(), XSSFWorkbook.PICTURE_TYPE_JPEG));
            fileOut = new FileOutputStream("D:/测试Excel.xlsx");
            // 写入excel文件
            wb1.write(fileOut);
            System.out.println("----Excle文件已生成------");
        } catch (Exception e) {
            e.printStackTrace();
        }finally{
            if(fileOut != null){
                try {
                    fileOut.close();
                } catch (IOException e) {
                    e.printStackTrace();
                }
            }
        }
    }
复制代码

 

posted @   不懒人  阅读(1472)  评论(0编辑  收藏  举报
编辑推荐:
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
阅读排行:
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
· 地球OL攻略 —— 某应届生求职总结
· 提示词工程——AI应用必不可少的技术
· Open-Sora 2.0 重磅开源!
· 周边上新:园子的第一款马克杯温暖上架
点击右上角即可分享
微信分享提示