Java从excel带图片的导入

注意:此种方法只适用于图片悬浮在单元格之上的图片搜寻!!!

 

首先导入相关poi的包:

        <dependency>
            <groupId>org.apache.poi</groupId>
            <artifactId>poi-ooxml</artifactId>
            <version>3.16</version>
        </dependency>

 Apache POI 是用Java编写的免费开源的跨平台的 Java API,Apache POI提供API给Java程式对Microsoft Office格式档案读和写的功能。POI为“Poor Obfuscation Implementation”的首字母缩写,意为“简洁版的模糊实现”。

读取表格内容的程序:

for (int i = 0; i < wookbook.getNumberOfSheets(); i++) {
            sheet=wookbook.getSheetAt(i);

            // 判断用07还是03的方法获取图片
            if(filePath.endsWith(".xls")){
                maplist=getPictures((HSSFSheet)sheet);
            }else if(filePath.endsWith(".xlsx")){
                maplist=getPictures((HSSFSheet)sheet);
            }
            printImg(maplist);
            //获得表头
            Row rowHead=sheet.getRow(0);
            if(rowHead.getPhysicalNumberOfCells()!=6)
            {
                System.out.println("表头的数量不对!");
                return;
            }
            //获得所有数据
            for(int j=1;j<=sheet.getLastRowNum();j++)
            {
                //获得第i行对象
                Row row=sheet.getRow(j);
                for (short k = 0; k < row.getLastCellNum(); k++) {
                    Cell cell=row.getCell(k);
                    System.out.println(getXCellVal(cell));
                }
            }
        }

 读取图片的具体代码:

/**
     * 获取excel表中的图片
     * @return
     * @Param fis 文件输入流
     * @Param sheetNum Excel表中的sheet编号
     * @throws IOException
     * @throws InvalidFormatException
     * @throws EncryptedDocumentException
     *
     * //说明Excel中的图片不在单元格内,而是悬浮在单元格之前,采用如下方式读取,
     * //但要求图片必须放在某个单元格之内也不能压住边框,否则获取的行数会有重复的。
     */
    public Map<String, HSSFPictureData> getPictures (HSSFSheet sheet)  throws  IOException {
        Map<String, HSSFPictureData> map =  new  HashMap<String, HSSFPictureData>();
        List<HSSFShape> list = sheet.getDrawingPatriarch().getChildren();
        for  (HSSFShape shape : list) {
            if  (shape  instanceof  HSSFPicture) {
                HSSFPicture picture = (HSSFPicture) shape;
                HSSFClientAnchor cAnchor = picture.getClientAnchor();
                HSSFPictureData pdata = picture.getPictureData();
                String key &#
  • 2
    点赞
  • 12
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值