Apache POI 操作Word常用方法

系列文章目录

一、Java使用Apache POI导出excel
二、Apache POI 操作Excel常用方法
三、Apache poi 拆分单元格并赋值
四、使用easypoi模板方法导出excel
五、Apache poi给excel单元格添加下拉框或数据验证
六、Apache poi操作Word常用方法

文章目录

  • 系列文章目录
  • 一、介绍
  • 二、Apache POI中的常用方法
    • 1.新建、读取、输出文档
      • 1、新建
      • 2、读取
      • 3、输出
    • 2.段落
      • 1、创建、写入段落
      • 2、获取段落
      • 3、获取段落文本、修改内容
      • 4、删除段落
      • 5、插入换行符
      • 6、段落格式
    • 3.字体
    • 4.边框
    • 5.表格
      • 1、创建表格、填写内容
      • 2、获取表格、修改内容
      • 3、设置表格行高、列宽
      • 4、设置边框
      • 5、设置背景色
      • 6、设置对齐方式
      • 7、合并
      • 8、拆分
    • 6.图片
      • 1、插入图片


一、介绍

本文介绍使用 Apache POI 操作Word文档(.docx)

引入依赖:

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

二、Apache POI中的常用方法

1.新建、读取、输出文档

1、新建

XWPFDocument document= new XWPFDocument();

2、读取

FileInputStream fileInputStream = new FileInputStream("D:/桌面/createdocument.docx");
XWPFDocument document= new XWPFDocument(fileInputStream);

3、输出

FileOutputStream out = new FileOutputStream("D:/桌面/createdocument.docx");
document.write(out);
document.close();
out.close();

2.段落

1、创建、写入段落

// 创建段落
XWPFParagraph paragraph = document.createParagraph();
// 运行段落
XWPFRun run = paragraph.createRun();
run.setText("北国风光,千里冰封,万里雪飘。\n" +"望长城内外,惟余莽莽;大河上下,顿失滔滔。\n" +"山舞银蛇,原驰蜡象,欲与天公试比高。\n" +"须晴日,看红装素裹,分外妖娆。\n" +"江山如此多娇,引无数英雄竞折腰。\n" +"惜秦皇汉武,略输文采;唐宗宋祖,稍逊风骚。\n" +"一代天骄,成吉思汗,只识弯弓射大雕。\n" +"俱往矣,数风流人物,还看今朝。");

2、获取段落

XWPFParagraph paragraph = document.getParagraph(ctp);  // 通过CTP获取段落
List<XWPFParagraph> paragraphs = document.getParagraphs();	// 获取段落集合
XWPFParagraph paragraphArray = document.getParagraphArray(1);	// 段落索引获取段落

3、获取段落文本、修改内容

String text = paragraph.getText();  // 获取段落后获取段落文本
// 获取段落后删除run,创建新的run并设置文本内容。
List<XWPFParagraph> paragraphs = document.getParagraphs();
paragraphs.getFirst().removeRun(0);
paragraphs.getFirst().createRun().setText("test");

4、删除段落

boolean b = document.removeBodyElement(0); // 段落索引删除// 通过段落内容删除
for (int i = 0; i < document.getParagraphs().size(); i++) {XWPFParagraph paragraph = document.getParagraphs().get(i);if (paragraph.getText().contains("想要删除的段落文本")) {document.removeBodyElement(i);break;}
}

5、插入换行符

run.addBreak();

6、段落格式

// 设置段落对齐方式
paragraph1.setAlignment(ParagraphAlignment.LEFT); // 设置段落缩进
paragraph1.setIndentationLeft(440); // 左缩进,单位为 twips(1 twip = 1/20 点)(字号 * 20 约为 缩进1字符)
paragraph1.setIndentationRight(440); // 右缩进
paragraph1.setIndentationFirstLine(440); // 首行缩进两字符// 设置段落行间距
CTPPr pPr = paragraph1.getCTP().getPPr();
CTSpacing spacing = pPr.isSetSpacing() ? pPr.getSpacing() : pPr.addNewSpacing();
spacing.setAfter(BigInteger.valueOf(220)); // 段前间距,单位为 twips
spacing.setBefore(BigInteger.valueOf(220)); // 段后间距
spacing.setLine(BigInteger.valueOf(360)); // 行间距,单位为 twips
spacing.setLineRule(STLineSpacingRule.AUTO); // 行间距规则// 设置段落间距
CTInd ind = pPr.isSetInd() ? pPr.getInd() : pPr.addNewInd();
ind.setLeft(BigInteger.valueOf(440)); // 左缩进
ind.setRight(BigInteger.valueOf(440)); // 右缩进
ind.setFirstLine(BigInteger.valueOf(440)); // 首行缩进

3.字体

run.setFontFamily("宋体"); // 设置字体名称
run.setFontSize(14); // 设置字体大小
run.setColor("FF0000"); // 设置字体颜色  红色
run.setBold(true); // 设置粗体
run.setItalic(true); // 设置斜体
run.setUnderline(UnderlinePatterns.SINGLE); // 设置下划线
run.setStrikeThrough(true); // 设置删除线

4.边框

paragraph.setBorderBottom(Borders.BASIC_BLACK_DASHES);
paragraph.setBorderLeft(Borders.BASIC_BLACK_DASHES);
paragraph.setBorderRight(Borders.BASIC_BLACK_DASHES);
paragraph.setBorderTop(Borders.BASIC_BLACK_DASHES);

5.表格

1、创建表格、填写内容

// 方式1
XWPFTable table = document.createTable(3, 3);
XWPFTableRow row = table.getRow(0); // 获取第一行
row.getCell(0).setText("Header 1"); // 设置单元格内容
row.getCell(1).setText("Header 2");
row.getCell(2).setText("Header 3");
XWPFTableRow newRow = table.createRow(); // 创建新的一行
newRow.getCell(0).setText("Data 1");
newRow.getCell(1).setText("Data 2");
newRow.getCell(2).setText("Data 3");// 方式2
XWPFTable table = document.createTable(); 
// 第一行
XWPFTableRow tableRowOne = table.getRow(0);
tableRowOne.getCell(0).setText("col one, row one");
tableRowOne.addNewTableCell().setText("col two, row one");
tableRowOne.addNewTableCell().setText("col three, row one");
// 第二行
XWPFTableRow tableRowTwo = table.createRow();
tableRowTwo.getCell(0).setText("col one, row two");
tableRowTwo.getCell(1).setText("col two, row two");
tableRowTwo.getCell(2).setText("col three, row two");
// 第三行
XWPFTableRow tableRowThree = table.createRow();
tableRowThree.getCell(0).setText("col one, row three");
tableRowThree.getCell(1).setText("col two, row three");
tableRowThree.getCell(2).setText("col three, row three");

2、获取表格、修改内容

// 假设我们要修改第一个表格
XWPFTable tables = document.getTables().getFirst();
// 假设我们要修改第一行第二列的单元格(索引从0开始)
int rowIndex = 0;
int cellIndex = 1;
XWPFTableRow row = tables.getRow(rowIndex);
if (row != null) {XWPFTableCell cell = row.getCell(cellIndex);if (cell != null) {// 清空单元格原有的所有段落for (int i = cell.getParagraphs().size() - 1; i >= 0; i--) {cell.removeParagraph(i);}// 添加新的段落到单元格XWPFParagraph paragraph = cell.addParagraph();XWPFRun run = paragraph.createRun();run.setText("这是新的单元格内容----------");}
}

3、设置表格行高、列宽

List<XWPFTableRow> rows = table.getRows();
List<XWPFTableCell> tableCells = rows.getFirst().getTableCells();
for (int i = 0; i < rows.size(); i++) {table.getRow(i).setHeight(1000); // 设置行高for (int j = 0; j < tableCells.size(); j++) {table.getRow(i).getCell(j).setWidth("3000"); // 设置列宽 必要时做null判断}
}

4、设置边框

// 设置外边框
table.setTopBorder(XWPFTable.XWPFBorderType.SINGLE, 20, 0, "006400"); // 线条样式 宽度 偏移 颜色
table.setBottomBorder(XWPFTable.XWPFBorderType.SINGLE, 20, 0, "006400");
table.setLeftBorder(XWPFTable.XWPFBorderType.SINGLE, 20, 0, "006400");
table.setRightBorder(XWPFTable.XWPFBorderType.SINGLE, 20, 0, "006400");CTTblBorders borders = table.getCTTbl().getTblPr().addNewTblBorders();
// 设置内边框
CTBorder hBorder = borders.addNewInsideH();
hBorder.setVal(STBorder.Enum.forString("double"));
hBorder.setSz(new BigInteger("1")); // 线条大小
hBorder.setColor("191970"); // 设置颜色CTBorder vBorder = borders.addNewInsideV();
vBorder.setVal(STBorder.Enum.forString("double"));
vBorder.setSz(new BigInteger("1"));
vBorder.setColor("191970");

5、设置背景色

CTShd shd = CTShd.Factory.newInstance();
shd.setFill("FF0000");  // 设置背景色为红色
cell.getCTTc().addNewTcPr().addNewShd().set(shd);

6、设置对齐方式

// 设置文本对齐方式
for (XWPFParagraph p : cell.getParagraphs()) {p.setAlignment(ParagraphAlignment.CENTER);  // 水平居中对齐
}
CTVerticalJc vjc = cell.getCTTc().addNewTcPr().addNewVAlign();
vjc.setVal(STVerticalJc.CENTER);  // 垂直居中对齐

7、合并

mergeCellsHorizontally(table, 0, 0, 2); // 合并第1行第1列到第3列
mergeCellsVertically(table, 1, 0, 2);   // 合并第2行第1列到第3行第1列private static void mergeCellsHorizontally(XWPFTable table, int row, int fromCol, int toCol) {for (int col = fromCol; col <= toCol; col++) {XWPFTableCell cell = table.getRow(row).getCell(col);if (col != fromCol) {cell.getCTTc().addNewTcPr().addNewHMerge().setVal(STMerge.RESTART);} else {cell.getCTTc().addNewTcPr().addNewHMerge().setVal(STMerge.RESTART);}}
}
private static void mergeCellsVertically(XWPFTable table, int fromRow, int col, int toRow) {for (int row = fromRow; row <= toRow; row++) {XWPFTableCell cell = table.getRow(row).getCell(col);if (row != fromRow) {cell.getCTTc().addNewTcPr().addNewVMerge().setVal(STMerge.CONTINUE);} else {cell.getCTTc().addNewTcPr().addNewVMerge().setVal(STMerge.RESTART);}}
}

8、拆分

splitCellsHorizontally(table, 0, 0, 2); // 拆分第1行第1列到第4列
splitCellsVertically(table, 1, 0, 2);   // 拆分第2行第1列到第3行第1列private static void splitCellsHorizontally(XWPFTable table, int row, int fromCol, int toCol) {for (int col = fromCol; col <= toCol; col++) {XWPFTableCell cell = table.getRow(row).getCell(col);if (col != fromCol) {removeHMerge(cell);}}
}private static void splitCellsVertically(XWPFTable table, int fromRow, int col, int toRow) {for (int row = fromRow; row <= toRow; row++) {XWPFTableCell cell = table.getRow(row).getCell(col);if (row != fromRow) {removeVMerge(cell);}}
}private static void removeHMerge(XWPFTableCell cell) {CTTcPr tcPr = cell.getCTTc().getTcPr();if (tcPr != null) {XmlCursor cursor = tcPr.newCursor();while (cursor.hasNextToken()) {if ("hMerge".equals(cursor.getName().getLocalPart())) {cursor.removeXml();break;}cursor.toNextToken();}cursor.dispose();}
}private static void removeVMerge(XWPFTableCell cell) {CTTcPr tcPr = cell.getCTTc().getTcPr();if (tcPr != null) {XmlCursor cursor = tcPr.newCursor();while (cursor.hasNextToken()) {if ("vMerge".equals(cursor.getName().getLocalPart())) {cursor.removeXml();break;}cursor.toNextToken();}cursor.dispose();}
}

6.图片

1、插入图片

 // 插入图片
String imagePath = "D:/桌面/128c46f7fa08b0eb7b6c17f5f2bb9b1.jpg";
FileInputStream imageStream = new FileInputStream(imagePath);
int format = XWPFDocument.PICTURE_TYPE_JPEG;
// 创建段落
XWPFParagraph paragraph = document.createParagraph();
// 运行段落
XWPFRun run = paragraph.createRun();
// 插入图片到段落中
run.addPicture(imageStream, format, imagePath, Units.toEMU(200), Units.toEMU(200));  // 图片宽高为 200px

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/885643.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

你对安装在自己网站上的wordpress插件了解吗?

有不少用wordpress建站的人&#xff0c;喜欢用插件实现一些功能&#xff0c;使用插件是可以很方便的实现一些功能&#xff0c;但是&#xff0c;使用插件也会带来不少的问题。关于这个&#xff0c;这里就不讲了&#xff0c;网上可以搜索出一堆相关的内容来&#xff0c;这里只提出…

H.264/H.265播放器EasyPlayer.js无插件H5播放器关于WASM的压缩优化

在当今的Web开发领域&#xff0c;流媒体播放器的性能和效率至关重要&#xff0c;尤其是在处理大型视频文件和高分辨率视频流时。EasyPlayer.js RTSP播放器作为一款先进的流媒体播放器&#xff0c;它在WebAssembly&#xff08;WASM&#xff09;的压缩优化方面表现出色&#xff0…

使用 Python 从 REST URL 下载文件

使用 Python 从 REST URL 下载文件&#xff0c;可以使用 requests 库来简化文件的下载和保存过程。以下是一个示例代码&#xff0c;展示了如何从给定的 REST API 或 URL 下载文件并保存到本地。 1、问题背景 我们需要编写一个脚本&#xff0c;从一个支持 REST URL 的网站下载一…

EKS+EBS

下面我们介绍一下如何在EKS中实现动态、可扩展高效的存储 总共用到五个内容&#xff1a; 1、ebs卷&#xff1a;物理存储资源&#xff0c;充当底层存储基础 2、ebs csl驱动&#xff1a;桥梁&#xff0c;允许K8s管理ebs 3、PV和PVC: 通过匹配让Pod挂载所需的持久存储 4、Pod的挂载…

SpringMVC学习记录(三)之响应数据

SpringMVC学习记录&#xff08;三&#xff09;之响应数据 一、页面跳转控制1、快速返回模板视图2、转发和重定向 二、返回JSON数据1、前置准备2、ResponseBody 三、返回静态资源1、静态资源概念2、访问静态资源 /*** TODO: 一个controller的方法是控制层的一个处理器,我们称为h…

利用EasyPOI导出Excel,内容中含有图片

需求背景 做一个OCR识别的功能,需要导出原图和识别出来的结果的图纸,将数据导出. 解决方案 EasyPOI中可以用字节类型,导出图片,可以将图片存放的url 转成字节,然后导出.但是整个导出过程耗时较久。 具体代码 /*** 草图OCR识别记录-导出.** @param response: Http…

ubuntu 22.04 server python3 包 LTS

ubuntu 22.04 server python3 包 LTS sudo apt install -y python3-pip 不同的用户的&#xff0c;包的 安装位置不一样 系统默认目录 /usr/lib/python3/dist-packages 然后每个用户 各自的目录是 /home/mike/.local/lib/python3.10/site-packages sudo apt install -y pytho…

CSDN做样板,教我们如何为新网站引流

CSDN为我们做了个很好的例子&#xff0c;详细请看下图 亮点分析&#xff1a; 1. 未采用硬广在网站上进行引流。减少了给用户在直觉上的造成的反感&#xff1b; 2. 在GitHub的转跳页面中&#xff0c;植入额外的关联网站链接。虽然对用户解决问题没啥鸟用&#xff0c;但是人家能…

【JAVA】Java基础—面向对象编程:构造方法-构造方法的概念与案例

在Java编程中&#xff0c;构造方法是类的重要组成部分&#xff0c;用于初始化对象的状态&#xff0c;即在创建对象时设置对象的属性。构造方法初始在创建对象时提供必要的参数&#xff0c;从而使对象处于一个有效的状态。 重要性 对象初始化&#xff1a;构造方法允许我们在创建…

【鉴权】 Web 会话管理:Cookie、Session 和 Token 深度解析

目录 引言一、Web 会话管理的基本概念1.1 Cookie、Session 和 Token1.2 为什么需要会话管理&#xff1f; 二、会话管理技术的比较2.1 Cookie 会话管理2.1.1 什么是 Cookie&#xff1f;2.1.2 Cookie 工作原理2.1.3 安全性问题2.1.4 最佳实践 2.2 Session 会话管理2.2.1 什么是 S…

什么是头皮EA(剥头皮EA)?

在许多外汇交易者的眼中&#xff0c;剥头皮交易一直是一个神秘的存在。一部分人认为它是一种“外汇禁招”&#xff0c;而另一部分人则认为它比日内交易更容易盈利。那么&#xff0c;外汇剥头皮到底是什么&#xff1f;它与点差之间又有怎样的关系&#xff1f;本文将对剥头皮交易…

1小时搞定魔乐平台AI应用的构建和离线复现

想象一下&#xff0c;只需一小时&#xff0c;你就能在魔乐平台上构建自己的AI应用&#xff0c;并在本地环境中完美复现。听起来是不是很诱人&#xff1f;今天&#xff0c;我们就来手把手教你如何快速上手魔乐社区的space服务&#xff0c;让你的AI创意变为现实。 一 前言&#x…

微服务架构面试内容整理-分布式配置管理-Nacos Config

Nacos Config 是 Nacos 提供的一个配置管理功能,专门用于动态管理应用的配置。在微服务架构中,Nacos Config 允许开发者集中管理和动态更新各个服务的配置,从而提升系统的灵活性和可维护性。以下是 Nacos Config 的主要特点、工作原理和使用场景: 主要特点 1. 动态配置管理…

yum安装zabbix5.0升级php到74的办法

【背景】 公司时不时有扫描漏洞,之前发现了php漏洞,因开启防火墙,限定IP+端口,暂时躲过升级;现在,老话重提,开启了KPI考核,躲是躲不过去的了,升级吧 【难题】 服务器为centos7,因操作系统问题,只能安装zabbix5.0。当时图省力,官网的办法,都是yum安装,很是简便。…

量化交易系统开发-实时行情自动化交易-3.3.数据采集流程

19年创业做过一年的量化交易但没有成功&#xff0c;作为交易系统的开发人员积累了一些经验&#xff0c;最近想重新研究交易系统&#xff0c;一边整理一边写出来一些思考供大家参考&#xff0c;也希望跟做量化的朋友有更多的交流和合作。 接下来说说数据采集流程&#xff0c;后…

华为ensp防火墙配置(纯享版)

文章目录 前言一、拓扑结构二、配置步骤1.路由器配置&#xff08;路由器代替互联网&#xff09;2.server和pc配置3.防护墙配置4.测试 总结 前言 防火墙是生活和项目中不可或缺的一部分&#xff0c;本篇文章对华为的ensp防火墙配置做一个总结。在之前的dhcp配置中有软件的下载地…

区块链技术在数字版权管理中的应用

&#x1f493; 博客主页&#xff1a;瑕疵的CSDN主页 &#x1f4dd; Gitee主页&#xff1a;瑕疵的gitee主页 ⏩ 文章专栏&#xff1a;《热点资讯》 区块链技术在数字版权管理中的应用 区块链技术在数字版权管理中的应用 区块链技术在数字版权管理中的应用 引言 区块链技术概述 …

go get 和go install 的区别

go get 和 go install 的主要区别&#xff1a; go get 的行为&#xff1a; 在 Go 1.17 之后&#xff0c;go get 主要用于修改 go.mod&#xff0c;添加、删除或者更新依赖安装的依赖包会记录在项目的 go.mod 文件中下载的包会存储在本地缓存目录: $GOPATH/pkg/mod/ 下示例&…

docker 拉取MySQL8.0镜像以及安装

目录 一、docker安装MySQL镜像 搜索images 拉取MySQL镜像 二、数据挂载 在/root/mysql/conf中创建 *.cnf 文件 创建容器,将数据,日志,配置文件映射到本机 检查MySQL是否启动成功&#xff1a; 三、DBeaver数据库连接 问题一、Public Key Retrieval is not allowed 问题…

云防护单节点2T抗攻击能力意味着什么?

随着互联网的发展&#xff0c;DDoS攻击的规模和频率不断增加&#xff0c;对企业和个人用户的网络服务造成了严重威胁。云防护服务作为一种高效的DDoS防护手段&#xff0c;逐渐成为许多企业的首选。本文将重点讨论云防护单节点2T&#xff08;太比特每秒&#xff09;抗攻击能力的…