java POI 如何实现Excel单元格内容换行
更新时间:2021年07月29日 10:38:17 作者:congcongxianshen
这篇文章主要介绍了java POI 如何实现Excel单元格内容换行的操作,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
java POI Excel单元格内容换行
pom.xml
<dependency> <groupId>org.apache.poi</groupId> <artifactId>poi</artifactId> <version>3.15</version> </dependency> <dependency> <groupId>org.apache.poi</groupId> <artifactId>poi-ooxml</artifactId> <version>3.15</version> </dependency> <dependency> <groupId>commons-io</groupId> <artifactId>commons-io</artifactId> <version>2.5</version> </dependency>
核心代码
@RestController public class MyController { @RequestMapping("/ip/v5") public void getExcel(HttpServletResponse response) throws IOException { ArrayList<String> arrayList = new ArrayList<String>(); arrayList.add("this is 单元格第1行"); arrayList.add("this is 单元格第2行"); arrayList.add("this is 单元格第3行"); arrayList.add("this is 单元格第4行"); XSSFWorkbook workBook = new XSSFWorkbook(); XSSFSheet sheet = workBook.createSheet(); workBook.setSheetName(0, "ip-v4表"); XSSFCellStyle cs = workBook.createCellStyle(); // 换行的关键,自定义单元格内容换行规则 cs.setWrapText(true); String fileName = "china-ip-v4" + ".xls";// 设置要导出的文件的名字 String[] headers = { "掩码" }; XSSFRow titleRow = sheet.createRow(0); // 在excel表中添加表头 for (int i = 0; i < headers.length; i++) { titleRow.createCell(i).setCellValue(headers[i]); } String content = String.join("\n", arrayList); int rowNum = 1; XSSFRow row1 = sheet.createRow(rowNum); // 创建一行 XSSFCell cell = row1.createCell(0); // 创建一个单元格 // 如下也是可以的 //cell.setCellValue("this is 单元格第1行 \n this is单元格第2行 \n this is 单元格第3行 \n this is 单元格第4行"); cell.setCellValue(content); cell.setCellStyle(cs); response.setContentType("application/octet-stream"); response.setHeader("Content-disposition", "attachment;filename=" + fileName); response.flushBuffer(); workBook.write(response.getOutputStream()); } }
结果:
poi单元格写值强制换行
String str="强制\r\n换行"
在字符串中间加上\r\n就行了~
以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。
相关文章
SpringBoot 整合Security权限控制的初步配置
这篇文章主要为大家介绍了SpringBoot 整合Security权限控制的初步配置实例,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪2022-11-11Java中wait与sleep的区别讲解(wait有参及无参区别)
这篇文章主要介绍了Java中wait与sleep的讲解(wait有参及无参区别),通过代码介绍了wait() 与wait( long timeout ) 区别,wait(0) 与 sleep(0)区别,需要的朋友可以参考下2022-04-04如何理解Java中基类子对象的构建过程从"基类向外"进行扩散的?
今天小编就为大家分享一篇关于如何理解Java中基类子对象的构建过程从"基类向外"进行扩散的?,小编觉得内容挺不错的,现在分享给大家,具有很好的参考价值,需要的朋友一起跟随小编来看看吧2019-04-04
最新评论