java poi生成word文档并下载
我使用的是Springboot框架开发的。首先需要在pom.xml文件中引入以下maven包:
1 2 3 4 5 6 7 8 9 10 11 12 | <dependency> <groupId>org.apache.poi</groupId> <artifactId>poi</artifactId> <version>3.10-FINAL</version> </dependency> <dependency> <groupId>org.apache.poi</groupId> <artifactId>poi-ooxml</artifactId> <version>3.8</version> </dependency> |
然后编写一个word工具类,使用时直接调用即可。
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 | package com.label.tool; import org.apache.poi.xwpf.usermodel.ParagraphAlignment; import org.apache.poi.xwpf.usermodel.XWPFDocument; import org.apache.poi.xwpf.usermodel.XWPFParagraph; import org.apache.poi.xwpf.usermodel.XWPFRun; import javax.servlet.http.HttpServletResponse; import java.io.OutputStream; import java.net.URLEncoder; import java.text.NumberFormat; import java.util.Map; public class WordTool { /** * * @param response * @throws Exception */ public static void downloadBigActivity(HttpServletResponse response) throws Exception { XWPFDocument doc = new XWPFDocument(); // 创建Word文件 XWPFParagraph p = doc.createParagraph(); // 新建段落 p.setAlignment(ParagraphAlignment.CENTER); // 设置段落的对齐方式 XWPFRun r = p.createRun(); //创建标题 r.setText( "2020年元日大型活动情况分析" ); r.setBold( true ); //设置为粗体 r.setColor( "000000" ); //设置颜色 r.setFontSize( 21 ); //设置字体大小 r.addCarriageReturn(); //回车换行 XWPFParagraph p1 = doc.createParagraph(); p1.setAlignment(ParagraphAlignment.BOTH); XWPFRun c1 = p1.createRun(); c1.setText( "一、12月31日晚上各地将举行各类活动" ); c1.setColor( "000000" ); c1.setFontSize( 12 ); c1.addCarriageReturn(); String fileNameURL = URLEncoder.encode( "myWord.doc" , "UTF-8" ); response.setCharacterEncoding( "UTF-8" ); //response.setHeader("Content-disposition", "attachment;filename=" + fileName); response.setContentType( "application/force-download" ); // 设置强制下载不打开 response.setHeader( "Content-disposition" , "attachment;filename=" + fileNameURL + ";" + "filename*=utf-8''" + fileNameURL); //response.setContentType("application/octet-stream"); //刷新缓冲 response.flushBuffer(); OutputStream ouputStream = response.getOutputStream(); //workbook将Excel写入到response的输出流中,供页面下载该Excel文件 doc.write(ouputStream); ouputStream.flush(); ouputStream.close(); } } |
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧
· 园子的第一款AI主题卫衣上架——"HELLO! HOW CAN I ASSIST YOU TODAY
· 【自荐】一款简洁、开源的在线白板工具 Drawnix