IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 移动开发 -> Java解析Excel 获取文本和图片信息 -> 正文阅读

[移动开发]Java解析Excel 获取文本和图片信息

1.引入jar

package org.apache.poi.hssf.usermodel;
package org.apache.poi.ooxml;
package org.apache.poi.ss.usermodel;

2.主要方法

 public static void getExcelText(String fileName, InputStream inputStreaml) throws Exception {
        FileTextVo vo = new FileTextVo();
        StringBuffer sb = new StringBuffer();
        Workbook wb = WorkbookFactory.create(inputStream);
        List<PictureData> pictureDataList = new ArrayList<>();
        for (int index = 0; index < wb.getNumberOfSheets(); index++) {
            //3.得到Excel工作表对象
            Sheet sheet = wb.getSheetAt(index);
            Map<String, PictureData> sheetIndexPicMap;
            if (fileName.toLowerCase().endsWith(".xls")) {
                sheetIndexPicMap = getSheetPictrues03(index, (HSSFSheet) sheet, (HSSFWorkbook) wb);
            } else {
                sheetIndexPicMap = getSheetPictrues07(index, (XSSFSheet) sheet, (XSSFWorkbook) wb);
            }
            if (!ObjectUtils.isEmpty(sheetIndexPicMap)) {
                for (PictureData photo : sheetIndexPicMap.values()) {
                    pictureDataList.add(photo);
                }
            }
            //总行数
            int trLength = sheet.getLastRowNum();
            //4.得到Excel工作表的行
            Row row = sheet.getRow(0);
            if (ObjectUtils.isEmpty(row)) {
                break;
            }
            //总列数
            int tdLength = row.getLastCellNum();
            Row rowtmp1 = sheet.getRow(1);
            if (rowtmp1 != null) {
                if (rowtmp1.getLastCellNum() > tdLength) {
                    tdLength = rowtmp1.getLastCellNum();
                }
            }
            Row rowtmp2 = sheet.getRow(1);
            if (rowtmp2 != null) {
                if (rowtmp2.getLastCellNum() > tdLength) {
                    tdLength = rowtmp2.getLastCellNum();
                }
            }
            //5.得到Excel工作表指定行的单元格
            for (int i = 0; i <= trLength; i++) {
                //得到Excel工作表的行
                Row row1 = sheet.getRow(i);
                if (row1 != null) {
                    for (int j = 0; j <= tdLength; j++) {
                        //得到Excel工作表指定行的单元格
                        Cell cell1 = row1.getCell(j);
                        //获得每一列中的值
                        if (cell1 != null) {
                            sb.append(cell1);
                        }
                    }
                }
            }
        }
        //图片识别
        if (!ObjectUtils.isEmpty(pictureDataList)) {
            for (PictureData photo : pictureDataList) {
                InputStream sbs = new ByteArrayInputStream(photo.getData());
            }
        }
        vo.setText(sb.toString());
        vo.setTotalPage(wb.getNumberOfSheets()); //将标签数作为总页数
    }


    //从03格式excel中获取图片
    public static Map<String, PictureData> getSheetPictrues03(int sheetNum,
                                                              HSSFSheet sheet, HSSFWorkbook workbook) {
        Map<String, PictureData> sheetIndexPicMap = new HashMap<String, PictureData>();
        List<HSSFPictureData> pictures = workbook.getAllPictures();
        if (pictures.size() != 0) {
            for (HSSFShape shape : sheet.getDrawingPatriarch().getChildren()) {
                HSSFClientAnchor anchor = (HSSFClientAnchor) shape.getAnchor();
                if (shape instanceof HSSFPicture) {
                    HSSFPicture pic = (HSSFPicture) shape;
                    int pictureIndex = pic.getPictureIndex() - 1;
                    HSSFPictureData picData = pictures.get(pictureIndex);
                    String picIndex = String.valueOf(sheetNum) + "_"
                            + String.valueOf(anchor.getRow1()) + "_"
                            + String.valueOf(anchor.getCol1());
                    sheetIndexPicMap.put(picIndex, picData);
                }
            }
            return sheetIndexPicMap;
        } else {
            return null;
        }
    }

    //07格式excel获取图片。
    public static Map<String, PictureData> getSheetPictrues07(int sheetNum,
                                                              XSSFSheet sheet, XSSFWorkbook workbook) {
        Map<String, PictureData> sheetIndexPicMap = new HashMap<String, PictureData>();
        for (POIXMLDocumentPart dr : sheet.getRelations()) {
            if (dr instanceof XSSFDrawing) {
                XSSFDrawing drawing = (XSSFDrawing) dr;
                List<XSSFShape> shapes = drawing.getShapes();
                for (XSSFShape shape : shapes) {
                    XSSFPicture pic = (XSSFPicture) shape;
                    XSSFClientAnchor anchor = pic.getPreferredSize();
                    CTMarker ctMarker = anchor.getFrom();
                    String picIndex = String.valueOf(sheetNum) + "_"
                            + ctMarker.getRow() + "_" + ctMarker.getCol();
//                    pic.getPictureData().getData();
                    sheetIndexPicMap.put(picIndex, pic.getPictureData());
                }
            }
        }
        return sheetIndexPicMap;
    }
  移动开发 最新文章
Vue3装载axios和element-ui
android adb cmd
【xcode】Xcode常用快捷键与技巧
Android开发中的线程池使用
Java 和 Android 的 Base64
Android 测试文字编码格式
微信小程序支付
安卓权限记录
知乎之自动养号
【Android Jetpack】DataStore
上一篇文章      下一篇文章      查看所有文章
加:2022-04-09 18:32:44  更:2022-04-09 18:32:46 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 -2024/11/24 20:54:34-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码