Java利用poi实现word表格转excel

2025-03-21 02:50
文章标签 java poi word excel 表格 实现

本文主要是介绍Java利用poi实现word表格转excel,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

《Java利用poi实现word表格转excel》这篇文章主要为大家详细介绍了Java如何利用poi实现word表格转excel,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下...

一、每行对象类

需要针对不同的表格进行对应的创建。

package org.example.wordToExcel;
/**
 * @Auther: rll
 * @Date: 2022/1/11 10:57
 * @Description: 每行对象类
 */
public class MyExcelBook {
 
    private String xuHao;
 
    private String yingYongMing;
 
    private String yiBenZhang;
 
    private String jianShu;
 
    private String jianShe;
 
    private String jiXiao;
 
    private String jinDu;
 
    private String qianTou;
 
    private String caChina编程nYu;
 
    public String getXuHao() {
        return xuHao;
    }
 
    public void setXuHao(String xuHao) {
        this.xuHao = xuHao;
    }
 
    public String getYingYongMing() {
        return yingYongMing;
    }
 
    public void setYingYongMing(String yingYongMing) {
        this.yingYongMing = yingYongMing;
    }
 
    public String getYiBenZhang() {
        return yiBenZhang;
    }
 
    public void setYiBenZhang(String yiBenZhang) {
        this.yiBenZhang = yiBenZhang;
    }
 
    public String getJianShu() {
        return jianShu;
    }
 
    public void setJianShu(String jianShu) {
        this.jianShu = jianShu;
    }
 
    public String getJianShe() {
        return jianShe;
    }
 
    public void setJianShe(String jianShe) {
        this.jianShe = jianShe;
    }
 
    public String getJiXiao() {
        return jiXiao;
    }
 
    public void setJiXiao(String jiXiao) {
        this.jiXiao = jiXiao;
    }
 
   编程 public String getJinDu() {
        return jinDu;
    }
 
    public void setJinDu(String jinDu) {
        this.jinDu = jinDu;
    }
 
    public String getQianTou() {
        return qianTou;
    }
 
    public void setQianTou(String qianTou) {
        this.qianTou = qianTou;
    }
 
    public String getCanYu() {
        return canYu;
    }
 
    public void setCanYu(String canYu) {
        this.canYu = canYu;
    }
}

二、转换测试

package org.example.wordToExcel;
 
import Java.beans.PropertyDescriptor;
import java.io.FileInputStream;
import java.io.FileOutputStream;
import java.lang.reflect.Field;
import java.lang.reflect.Method;
import java.util.ArrayList;
 
import org.apache.poi.hssf.usermodel.HSSFRow;
import org.apache.poi.hssf.usermodel.HSSFSheet;
import org.apache.poi.hssf.usermodel.HSSFWorkbook;
import org.apache.poi.hwpf.HWPFDocument;
import org.apache.poi.hwpf.usermodel.Paragraph;
import org.apache.poi.hwpf.usermodel.Range;
import org.apache.poi.hwpf.usermodel.Table;
import org.apache.poi.hwpf.usermodel.TableCell;
import org.apache.poi.hwpf.usermodel.TableIterator;
import org.apache.poi.hwpf.usermodel.TableRow;
import org.apache.poi.poifs.filesystem.POIFSFileSystem;
 
/**
 * @Auther: rll
 * @Date: 2022/1/11 15:57
 * @Description: word表格转excel
 */
public class ReadwordToWriteExcel {
 
    static String fileName = "C:\\Users\\Desktop\\testFile";
 
    public static void main(String[] args) throws Exception {
        readWord();
    }
 
    public static void readWord() {
 
        ArrayList<MyExcelBook> list = new ArrayList<>();
        list.clear();
        try {
 
            FileInputStream in = new FileInputStream(fileName + ".doc");//载入文档
编程China编程            POIFSFileSystem pfs = new POIFSFileSystem(in);
            HWPFDocument hwpf = new HWPFDocument(pfs);
            Range range = hwpf.getRange();
            TableIterator it = new TableIterator(range);
 
            //遍历word
            while (it.hasNext()) {
                Table tb = it.next();
                //遍历行
                for (int i = 0; i < tb.numRows(); i++) {
                    TableRow tr = tb.getRow(i);
                    //迭代列
                    MyExcelBook excelBook = new MyExcelBook();
                    Class aClass = excelBook.getClass();
                    for (int j = 0; j < tr.numCells(); j++) {
                        TableCell td = tr.getCell(j);//取得单元格
                        //取得单元格的内容
                        Field[] fields = aClass.getDeclaredFields();
 
                        //遍历单元格所有内容放入一个sb
                        StringBuilder sb = new StringBuilder();
                        for (int k = 0; k < td.numParagraphs(); k++) {
                            Paragraph para = td.getParagraph(k);
                            String s = para.text();
                            sb.append(s);
                        }
                        //反射遍历excel字段,赋值给book对象
                        //反射赋值和取值
                        Field field = fields[j];
                        String fieldName = field.getName();
                        PropertyDescriptor pd = new jsPropertyDescriptor(field.getName(),
                                aClass);
 
                        // 获取set方法
                        Method setMethod = pd.getWriteMethod();
                        setMethod.invoke(excelBook, sb.deleteCharAt(sb.length() - 1).toString());//去掉最后一个标记符号
 
                        sb.delete(0, sb.length());
                    }
                    list.add(excelBook);
                }
            }
 
            writeExecl(list);
 
        } catch (Exception e) {
            e.printStackTrace();
        }
    }
 
    public static void writeExecl(ArrayList<MyExcelBook> list) throws Exception {
        //创建一个webbook,对应一个Excel文件
        HSSFWorkbook wb = new HSSFWorkbook();
        //在webbook中添加一个sheet,对应Excel文件中的sheet
        HSSFSheet sheet = wb.createSheet("sheet1");
 
        HSSFRow row = null;
 
        for (int i = 0; i < list.size(); i++) {
            //在sheet中添加行
            row = sheet.createRow(i);
            MyExcelBook excelBook = list.get(i);
 
            //反射取值
            Class aClass = excelBook.getClass();
            Field[] fields = aClass.getDeclaredFields();
            for (int j = 0; j < fields.length; j++) {
                Field field = fields[j];
                String fieldName = field.getName();
                PropertyDescriptor pd = new PropertyDescriptor(fieldName,
                        aClass);
                //get方法
                Method getMethod = pd.getReadMethod();
                //创建单元格
                row.createCell(j).setCellValue(String.valueOf(getMethod.invoke(excelBook)));
            }
 
        }
        //生成文件
        try {
            FileOutputStream fout = new FileOutputStream(fileName + ".xls");
            wb.write(fout);
            fout.close();
        } catch (Exception e) {
            e.printStackTrace();
        }
 
    }
 
}

测试的word文档,请使用只有表格且没有合并表格的进行测试,

请使用只有表格且没有合并表格的进行测试,

请使用只有表格且没有合并表格的进行测试。

到此这篇关于Java利用poi实现word表格转excel编程的文章就介绍到这了,更多相关Java word转excel内容请搜索China编程(www.chinasem.cn)以前的文章或继续浏览下面的相关文章希望大家以后多多支持China编程(www.chinasem.cn)!

这篇关于Java利用poi实现word表格转excel的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1153857

相关文章

Python实现常用文本内容提取

《Python实现常用文本内容提取》在日常工作和学习中,我们经常需要从PDF、Word文档中提取文本,本文将介绍如何使用Python编写一个文本内容提取工具,有需要的小伙伴可以参考下... 目录一、引言二、文本内容提取的原理三、文本内容提取的设计四、文本内容提取的实现五、完整代码示例一、引言在日常工作和学

Python实战之屏幕录制功能的实现

《Python实战之屏幕录制功能的实现》屏幕录制,即屏幕捕获,是指将计算机屏幕上的活动记录下来,生成视频文件,本文主要为大家介绍了如何使用Python实现这一功能,希望对大家有所帮助... 目录屏幕录制原理图像捕获音频捕获编码压缩输出保存完整的屏幕录制工具高级功能实时预览增加水印多平台支持屏幕录制原理屏幕

SpringBoot3使用Jasypt实现加密配置文件

《SpringBoot3使用Jasypt实现加密配置文件》这篇文章主要为大家详细介绍了SpringBoot3如何使用Jasypt实现加密配置文件功能,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编... 目录一. 使用步骤1. 添加依赖2.配置加密密码3. 加密敏感信息4. 将加密信息存储到配置文件中5

Python实现自动化表单填写功能

《Python实现自动化表单填写功能》在Python中,自动化表单填写可以通过多种库和工具实现,本文将详细介绍常用的自动化表单处理工具,并对它们进行横向比较,可根据需求选择合适的工具,感兴趣的小伙伴跟... 目录1. Selenium简介适用场景示例代码优点缺点2. Playwright简介适用场景示例代码

SpringBoot整合jasypt实现重要数据加密

《SpringBoot整合jasypt实现重要数据加密》Jasypt是一个专注于简化Java加密操作的开源工具,:本文主要介绍详细介绍了如何使用jasypt实现重要数据加密,感兴趣的小伙伴可... 目录jasypt简介 jasypt的优点SpringBoot使用jasypt创建mapper接口配置文件加密

SpringBoot整合MybatisPlus的基本应用指南

《SpringBoot整合MybatisPlus的基本应用指南》MyBatis-Plus,简称MP,是一个MyBatis的增强工具,在MyBatis的基础上只做增强不做改变,下面小编就来和大家介绍一下... 目录一、MyBATisPlus简介二、SpringBoot整合MybatisPlus1、创建数据库和

解读spring.factories文件配置详情

《解读spring.factories文件配置详情》:本文主要介绍解读spring.factories文件配置详情,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录使用场景作用内部原理机制SPI机制Spring Factories 实现原理用法及配置spring.f

jvm调优常用命令行工具详解

《jvm调优常用命令行工具详解》:本文主要介绍jvm调优常用命令行工具的用法,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一 jinfo命令查看参数1.1 查看jvm参数二 jstack命令2.1 查看现场堆栈信息三 jstat 实时查看堆内存,gc情况3.1

SpringBoot项目使用MDC给日志增加唯一标识的实现步骤

《SpringBoot项目使用MDC给日志增加唯一标识的实现步骤》本文介绍了如何在SpringBoot项目中使用MDC(MappedDiagnosticContext)为日志增加唯一标识,以便于日... 目录【Java】SpringBoot项目使用MDC给日志增加唯一标识,方便日志追踪1.日志效果2.实现步

解决Java中基于GeoTools的Shapefile读取乱码的问题

《解决Java中基于GeoTools的Shapefile读取乱码的问题》本文主要讨论了在使用Java编程语言进行地理信息数据解析时遇到的Shapefile属性信息乱码问题,以及根据不同的编码设置进行属... 目录前言1、Shapefile属性字段编码的情况:一、Shp文件常见的字符集编码1、System编码