springboot集成easypoi导出word换行处理过程
作者:涛哥是个大帅比
Spring Boot集成Easypoi导出Word时,换行符\n失效显示为空格,解决方法包括生成段落或替换模板中\n为回车,同时需确保变量{{temp}}在Map中设为" "(带空格空字符串),避免空指针或残留变量
项目场景
springboot集成easypoi导出word
<dependency> <groupId>cn.afterturn</groupId> <artifactId>easypoi-spring-boot-starter</artifactId> <version>4.4.0</version> </dependency>
问题描述
spring boot集成easypoi导出word时,内容包含换行符\n,导出word时换行符失效,会将换行符\n识别为空格。
解决方案
第一种:生成段落的方式
示例代码:
import com.xinghuo.common.base.ActionResult;
import io.swagger.annotations.Api;
import io.swagger.annotations.ApiOperation;
import lombok.Cleanup;
import org.apache.poi.xwpf.usermodel.XWPFDocument;
import org.apache.poi.xwpf.usermodel.XWPFParagraph;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
import java.io.File;
import java.io.FileOutputStream;
@RestController
@Api(tags = "测试")
@RequestMapping("/test")
public class TestController {
@ApiOperation("导出Word")
@GetMapping("/export")
public ActionResult export() {
exportWord();
return ActionResult.success();
}
/**
* 导出Word,支持换行
*/
public void exportWord(){
try{
String content = "第一行\n第二行中文\n"+"第三行";
@Cleanup XWPFDocument doc = new XWPFDocument();
if(content != null && content.contains("\n")) {
//设置换行
String[] text = content.split("\n");
for (int i = 0; i < text.length; i++) {
XWPFParagraph p = doc.createParagraph();
p.createRun().setText(text[i]);
}
}else{
XWPFParagraph p = doc.createParagraph();
p.createRun().setText(content);
}
String name = "测试换行内容.docx";
String filePath = "F:"+ File.separator + name;
@Cleanup FileOutputStream output = new FileOutputStream(filePath);
doc.write(output);
} catch (Exception e) {
e.printStackTrace();
}
}
}导出的word内容

第二种:替换模板的情况,换行符替换成回车
示例代码:
import cn.afterturn.easypoi.word.WordExportUtil;
import com.xinghuo.common.base.ActionResult;
import com.xinghuo.common.util.XSSEscape;
import io.swagger.annotations.Api;
import io.swagger.annotations.ApiOperation;
import lombok.Cleanup;
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.GetMapping;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
import java.io.File;
import java.io.FileOutputStream;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
@RestController
@Api(tags = "测试")
@RequestMapping("/test")
public class Test1Controller {
@ApiOperation("导出Word")
@GetMapping("/export")
public ActionResult export() {
exportWordTemplate();
return ActionResult.success();
}
/**
* 导出Word替换模板,支持换行
*/
public void exportWordTemplate(){
try{
String content = "第一行\n第二行中文\n"+"第三行";
Map<String, Object> map = new HashMap<>();
map.put("content",content);
@Cleanup XWPFDocument doc = WordExportUtil.exportWord07("F:/export_template.docx", map);
//文本换行
addBreakInCell(doc.getParagraphs());
String name = "测试换行内容-替换模板.docx";
String filePath = "F:"+ File.separator + name;
@Cleanup FileOutputStream output = new FileOutputStream(XSSEscape.escapePath(filePath));
doc.write(output);
} catch (Exception e) {
e.printStackTrace();
}
}
/**
* 文本换行
*/
public static void addBreakInCell(List<XWPFParagraph> paragraphs) {
for (XWPFParagraph p : paragraphs) {
for (XWPFRun run : p.getRuns()) {//XWPFRun对象定义具有一组公共属性的文本区域
if(run.getText(0)!= null && run.getText(0).contains("\n")) {
String[] lines = run.getText(0).split("\n");
if(lines.length > 0) {
run.setText(lines[0], 0); // set first line into XWPFRun
for(int i=1;i<lines.length;i++){
// add break and insert new text
run.addBreak();//中断
// run.addCarriageReturn();//回车符,但是不起作用
run.setText(lines[i]);
}
}
}
}
}
}
}其中export_template.docx文件是word模板,内容为:

导出的内容

导出的本地文件截图

总结
注意:模板中有变量值{{temp}},参数Map里面对应的temp值是null或者"",导出的word就会变成抛空指针异常或者{{temp}}、其他带{{ 的形式,直接在Map中设置temp的值为" ",就可以导出空白到模板,注意是加了空格的字符串" "。
以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。
