zoukankan      html  css  js  c++  java
  • 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();
                    }
                }
            }
        }
  • 相关阅读:
    Beta 冲刺(4/7)
    Beta 冲刺(3/7)
    Beta 冲刺(2/7)
    Beta 冲刺(1/7)
    福大软工 · BETA 版冲刺前准备(团队) [已完成]
    解决Mac外接显示器分辨率不正确问题
    oracle11g客户端如何完全卸载(转)
    【转】VMware设置共享文件夹之后Ubuntu中看不到怎么办?
    解决无法将程序加到默认程序打开列表中的问题(转)
    设置无线上网和本地上网的优先级
  • 原文地址:https://www.cnblogs.com/wuwuyong/p/15018755.html
Copyright © 2011-2022 走看看