Java【代码 18】处理Word文档里的Excel表格数据(源码分享)

1.原始数据

Word 文档里的 Excel 表格数据,以下仅为示例数据:

读取后的字符串数据为:

json 复制代码
"姓名\r\n身份证号\r\n手机号\r\n户籍地\r\n张三丰\r\n411381198909092222\r\n15713862222\r\n河南郑州\r\n李四方\r\n411381198909093333\r\n15713863333\r\n河南新乡\r\n王五福\r\n411381198909095555\r\n15713865555\r\n河南安阳\r\n"

每个字段都有换行:

latex 复制代码
姓名
身份证号
手机号
户籍地
张三丰
411381198909092222
15713862222
河南郑州
李四方
411381198909093333
15713863333
河南新乡
王五福
411381198909095555
15713865555
河南安阳

2.处理程序

2.1 识别替换表格表头

首先要定位表格数据的开始和结束,示例中的 sonString表格前面有一些数据,表格的后面就没有数据了【要注意这点儿】。

java 复制代码
    /**
     * 处理包含表格的正文字符串
     *
     * @param sonString 正文字符串
     * @return 处理后的正文字符串
     */
    private String deal(String sonString) {
        // 1.判断是否存在表格固定表头
        boolean contains = sonString.contains("姓名\r\n身份证号\r\n手机号\r\n户籍地\r\n");
        if (contains) {
            String headerStr = "姓名,身份证号,手机号,户籍地\r\n";
            // 2.将换行数据处理为一行数据
            sonString = sonString.replace("姓名\r\n身份证号\r\n手机号\r\n户籍地\r\n", headerStr);
            // 3.处理表格数据
            int headerIndex = sonString.indexOf(headerStr);
            String personInfoStr = sonString.substring(headerIndex + headerStr.length());
            // 4.处理人员信息
            String personInfo = dealPersonInfoStr(personInfoStr);
            // 5.替换原有数据
            sonString = sonString.replace(personInfoStr, personInfo);
        }
        return sonString;
    }

2.2 处理多余的换行符

java 复制代码
    /**
     * 处理每行数据里多余的换行符
     *
     * @param personInfoStr 人员信息
     * @return 处理后的人员信息
     */
    private String dealPersonInfoStr(String personInfoStr) {
        int infoLength = 4;
        String[] infoArr = personInfoStr.split("\r\n");
        StringBuilder personInfo = new StringBuilder();
        for (int i = 1; i < infoArr.length + 1; i++) {
            if (i % infoLength == 0) {
                personInfo.append(infoArr[i - 1]).append("\r\n");
            } else {
                personInfo.append(infoArr[i - 1]).append(",");
            }
        }
        return personInfo.toString();
    }

2.3 处理后的结果

json 复制代码
"姓名,身份证号,手机号,户籍地\r\n张三丰,411381198909092222,15713862222,河南郑州\r\n李四方,411381198909093333,15713863333,河南新乡\r\n王五福,411381198909095555,15713865555,河南安阳\r\n"
latex 复制代码
姓名,身份证号,手机号,户籍地
张三丰,411381198909092222,15713862222,河南郑州
李四方,411381198909093333,15713863333,河南新乡
王五福,411381198909095555,15713865555,河南安阳

3.总结

  • 代码是根据固定表头进行的处理,表头信息可以进行配置;
  • 需要定位表格数据。
相关推荐
微笑听雨11 分钟前
基于 Drools 的规则引擎性能调优实践:架构、缓存与编译优化全解析
java·后端
五岁小孩吖23 分钟前
实操使用 go pprof 对生产环境进行性能分析(问题定位及代码优化)
后端
_風箏25 分钟前
Java【代码 21】将word、excel文件转换为pdf格式和将pdf文档转换为image格式工具类分享(Gitee源码)aspose转换中文乱码问题处理
后端
景天科技苑26 分钟前
【Rust多进程】征服CPU的艺术:Rust多进程实战指南
开发语言·后端·rust·rust多进程·rust进程·多进程编程
随意石光27 分钟前
JWT在Spring Security中的实战应用:认证、授权一网打尽
后端
就是帅我不改30 分钟前
深入实战模板方法模式与装饰器模式:模板方法模式与装饰器模式在电商系统中的应用
后端
hello早上好30 分钟前
Spring AOP MethodInvocation 工作原理
java·后端·架构
Emma歌小白1 小时前
Vetur can't find tsconfig.json, jsconfig.json in /xxxx/xxxxxx.
javascript·后端
大葱白菜1 小时前
JavaWeb 进阶:Vue.js 与 Spring Boot 全栈开发实战(Java 开发者视角)
前端·后端·程序员
大葱白菜1 小时前
JavaWeb 核心:AJAX 深入详解与实战(Java 开发者视角)
前端·后端·程序员