当前位置: 首页 > wzjs >正文

企业网站服务器的选择新手学wordpress

企业网站服务器的选择,新手学wordpress,学习网站开发心得,网站建设百度认证一、背景介绍: 在我们日常工作中,难免遇到需要导出docx文件的时候,也就是导出word文件,今天就简单介绍一下通过POI的XWPFDocument来导出word文件。 二、代码实现: 2.1、word文本 我们给导出的word文件写一段文字。 p…

一、背景介绍:

        在我们日常工作中,难免遇到需要导出docx文件的时候,也就是导出word文件,今天就简单介绍一下通过POI的XWPFDocument来导出word文件。

二、代码实现:

        2.1、word文本

        我们给导出的word文件写一段文字。

package com.relation.web.controller.export;import lombok.extern.slf4j.Slf4j;
import org.apache.poi.xwpf.usermodel.XWPFDocument;
import org.apache.poi.xwpf.usermodel.XWPFParagraph;
import org.apache.poi.xwpf.usermodel.XWPFRun;
import org.springframework.web.bind.annotation.PostMapping;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;import javax.servlet.ServletOutputStream;
import javax.servlet.http.HttpServletResponse;
import java.net.URLEncoder;
import java.util.Objects;/*** @author huhy* @version 1.0* @Description:* @ClassName Date:2025/6/28 23:17*/
@Slf4j
@RestController
@RequestMapping("/testExportController")
public class TestExportController {@PostMapping("/exportWordFile")public void exportWordFile(HttpServletResponse response){//创建XWPFDocumentXWPFDocument doc = new XWPFDocument();//创建段落XWPFParagraph p = doc.createParagraph();XWPFRun run = p.createRun();run.setText("这是一个测试文本");run.setFontSize(14);ServletOutputStream outputStream = null;try{outputStream = response.getOutputStream();response.setHeader("Access-Control-Expose-Headers", "Content-Disposition");response.setHeader("Content-Disposition", "attachment; filename="+ URLEncoder.encode("测试导出.docx", "UTF-8"));doc.write(outputStream);}catch (Exception e){log.error(e.getMessage(),e);throw new RuntimeException("导出异常");}finally {if(Objects.nonNull(outputStream)){try {outputStream.close();doc.close();}catch (Exception e){}}}}
}

        2.2、word表格

        2.1中给word中写了一段文字,这次我们给word文件写一个表格。

package com.relation.web.controller.export;import lombok.extern.slf4j.Slf4j;
import org.apache.poi.xwpf.usermodel.*;
import org.openxmlformats.schemas.wordprocessingml.x2006.main.CTTblWidth;
import org.openxmlformats.schemas.wordprocessingml.x2006.main.STTblWidth;
import org.springframework.web.bind.annotation.PostMapping;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;import javax.servlet.ServletOutputStream;
import javax.servlet.http.HttpServletResponse;
import java.math.BigInteger;
import java.net.URLEncoder;
import java.util.Objects;/*** @author huhy* @version 1.0* @Description:* @ClassName Date:2025/6/28 23:17*/
@Slf4j
@RestController
@RequestMapping("/testExportController")
public class TestExportController {@PostMapping("/exportWordFile")public void exportWordFile(HttpServletResponse response){//创建XWPFDocumentXWPFDocument doc = new XWPFDocument();//创建段落XWPFParagraph p = doc.createParagraph();XWPFRun run = p.createRun();run.setText("这是一个测试文本");run.setFontSize(14);//初始化一个两行、4列的表格XWPFTable table = doc.createTable(2, 4);CTTblWidth width = table.getCTTbl().addNewTblPr().addNewTblW();width.setType(STTblWidth.PCT);width.setW(BigInteger.valueOf(5000)); // 5000=100%table.getRow(0).getCell(0).setText("导出测试表格");String[] headers = {"序号","姓名","年龄","城市"};for(int i=0; i<headers.length; i++) {table.getRow(1).getCell(i).setText(headers[i]);}// 添加数据行String[][] data = {{"1","小永哥","18","北京"},{"2","胡彪","45","吉林"}};for(String[] rowData : data) {XWPFTableRow row = table.createRow();for(int i=0; i<rowData.length; i++) {row.getCell(i).setText(rowData[i]);}}ServletOutputStream outputStream = null;try{outputStream = response.getOutputStream();response.setHeader("Access-Control-Expose-Headers", "Content-Disposition");response.setHeader("Content-Disposition", "attachment; filename="+ URLEncoder.encode("测试导出.docx", "UTF-8"));doc.write(outputStream);}catch (Exception e){log.error(e.getMessage(),e);throw new RuntimeException("导出异常");}finally {if(Objects.nonNull(outputStream)){try {outputStream.close();doc.close();}catch (Exception e){}}}}
}

        2.3、基于模板导出

        在2.1和2.2步骤中,我们已经实现了简单的文本和表格的输出,不过代码基本上写死了,不太灵活,其实在实际开发过程中,常用的套路是创建模板,然后用真实的数据替换模板中的占位符或者是书签来达到动态生成文件的效果,我们简单来实现一下。

        2.3.1、首先创建一个模板,然后给模板中添加一下书签。

        2.3.2、将创建好书签的模板存放到某个位置,这个位置可以是本地、也可以是文件服务器上,这个按实际项目要求来就好。

        

package com.relation.web.controller.export;import lombok.extern.slf4j.Slf4j;
import org.apache.poi.xwpf.usermodel.XWPFDocument;
import org.apache.poi.xwpf.usermodel.XWPFParagraph;
import org.apache.poi.xwpf.usermodel.XWPFTable;
import org.apache.poi.xwpf.usermodel.XWPFTableRow;
import org.openxmlformats.schemas.wordprocessingml.x2006.main.CTBookmark;
import org.springframework.core.io.ClassPathResource;
import org.springframework.core.io.Resource;
import org.springframework.web.bind.annotation.PostMapping;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;import javax.servlet.ServletOutputStream;
import javax.servlet.http.HttpServletResponse;
import java.net.URLEncoder;
import java.util.List;
import java.util.Objects;/*** @author huhy* @version 1.0* @Description:* @ClassName Date:2025/6/28 23:17*/
@Slf4j
@RestController
@RequestMapping("/testExportController")
public class TestExportController {@PostMapping("/exportWordFile")public void exportWordFile(HttpServletResponse response){Resource resource = new ClassPathResource("model/导出模板.docx");//创建XWPFDocumentXWPFDocument doc = null;ServletOutputStream outputStream = null;try{doc = new XWPFDocument(resource.getInputStream());//获取段落List<XWPFParagraph> paragraphs = doc.getParagraphs();for (XWPFParagraph paragraph : paragraphs) {//从段落中获取书签List<CTBookmark> bookmarkStartList = paragraph.getCTP().getBookmarkStartList();for (CTBookmark ctBookmark : bookmarkStartList) {String ctBookmarkName = ctBookmark.getName();if("exportTitle".equals(ctBookmarkName)){// 清除原有内容paragraph.getRuns().forEach(run -> run.setText("", 0));// 添加新内容paragraph.createRun().setText("导出测试标题!!");}if("tableTitle".equals(ctBookmarkName)){// 清除原有内容paragraph.getRuns().forEach(run -> run.setText("", 0));// 添加新内容paragraph.createRun().setText("测试导出表格标题!!");}if("tableInfo".equals(ctBookmarkName)){// 在书签位置创建表格XWPFTable table = doc.insertNewTbl(paragraph.getCTP().newCursor());//删除默认行table.removeRow(0);//插入3行for (int i = 0; i < 3; i++) {table.createRow();}List<XWPFTableRow> rows = table.getRows();String[] headers = {"序号","姓名","年龄","城市"};XWPFTableRow headerRow = table.getRow(0);for(int i=0; i<headers.length; i++) {headerRow.createCell().setText(headers[i]);}// 添加数据行String[][] data = {{"1","小永哥","18","北京"},{"2","胡彪","45","吉林"}};for (int i = 0; i < data.length; i++) {XWPFTableRow row = table.getRow(i+1);String[] rowData = data[i];for(int j=0; j<rowData.length; j++) {row.createCell().setText(rowData[j]);}}}}}//检查段落中的书签outputStream = response.getOutputStream();response.setHeader("Access-Control-Expose-Headers", "Content-Disposition");response.setHeader("Content-Disposition", "attachment; filename="+ URLEncoder.encode("测试导出.docx", "UTF-8"));doc.write(outputStream);}catch (Exception e){log.error(e.getMessage(),e);throw new RuntimeException("导出异常");}finally {if(Objects.nonNull(outputStream)){try {outputStream.close();doc.close();}catch (Exception e){}}}}
}

        可以看到,我们通过在模板中设置书签,在代码中定位书签替换内容就能完成导出word,虽然XWPFDocument类还有其他的功能,不过经过这次分享,大家应该对XWPFDocument有了一定的了解,其他的功能就不多做介绍了,大家自行发掘。

三、结语

        导出word说实话不是什么冷门的需求,但是大多数老铁听说过但是自己做的少,比如说我吧,之前就有这个需求,但任务当时是安排给了其他同事,所以小永哥就没再多做了解,所以对这个功能一直处于一知半解的,直到有一天自己遇到了这个需求才真正花精力去学习了解了一番。

        好了本次就先分享到这里,如果对老铁们有帮助,还希望可以给小永哥点个赞,谢谢大家......

http://www.dtcms.com/wzjs/536484.html

相关文章:

  • 数据交易网站源码三站一体网站公司
  • 阿里云买了域名怎么建网站深圳企业黄页
  • 做文学网站用什么域名苏州网站建设业务的公司
  • 管理外贸网站模板wordpress开发文档
  • 建设实木餐桌椅移动网站织梦网站logo修改
  • 临清网站建设费用建设银行网站上的的研究报告
  • 巩义网站网站建设免费的个人网站注册
  • wordpress怎么做响应式网站网站建立吸引人的策划活动
  • 网站建设系统开发需要多少钱网站开发用什么系统比较好
  • 效果图网站源码360建筑网这家公司怎么样
  • 阿克苏网站建设服务茂名网站建设制作
  • 建筑招标网站西安网站建设定制
  • 哪个网站推广产品好搜索引擎和浏览器
  • 怎么做网站咨询设计经典网站
  • 企业网站建设可以分为( )交互层次用记事本制作html网页
  • 成都网站优化排名推广wordpress采集功能
  • 网站建设用什么系统企业为什么要网站建设
  • 在家帮别人做网站赚钱.net如何兼容手机网站
  • 电子商务网站建设的一般优秀的网站建设
  • 全椒做网站网站建设进度汇报
  • 中方建设局网站在线销售型网站产品
  • 洛阳东翔科技做的网站权威的合肥网站建设
  • 怎么看网站是谁做的网站备份 ftp
  • 亚洲男女做暖网站一家专做特卖的网站
  • 设计logo网站免费横屏纯色建设网站的编程过程
  • 网站编辑信息怎么做定制做网站费用
  • 医院英文网站建设人人建站网
  • 做爰片免费网站给我看看做网站模版与定制的区别
  • 益阳网站设计公司门户网站建设周期
  • 青岛网站建设的方案桂林漓江风景图片