本文主要是将数据库取出的数据按照自定义的行列格式导出到excel中,POI则是实现我们需求所用到的技术。

  • POI介绍
  • 使用spring boot导入相关依赖
  • 获取数据(自行处理)
  • 完整代码实例:创建excel,将数据写入excel

1.POI介绍

要想使用POI对Excel进行操作,我们需要先了解一下Excel的两种版本:一种是97-2003版本扩展名是“.xls”;一种是2007版本扩展名是“.xlsx”。POI分别针对这两种版本需要导入的jar包不同,操作类也不同。

HSSF:操作的是.xls;XSSF:操作的是.xlsx。

不管哪种操作,基本思路都是一致,先要对应一个Excel文件,然后在对应文件中的某个sheet,接下来在操作某一行和这一行中的某一列。对应POI包:文件(webbook)、sheet(sheet)、行(row)和具体单元格(cell)。

详细操作请参照POI官网的Excel(HSSF/XSSF)操作

2.通过spring boot导入依赖

为了使用java操控excel,需要将相关的jar引入,对于HSSF只需要导入POI.jar,而XSSF则需要导入四个jar,具体导入见下面代码

将代码块的依赖放入工程的pom.xml文件中就可以了。

工程不是spring boot的需要手动将下面jar导入。

  1. <!-- HSSF需要引入的 -->
  2. <dependency>
  3. <groupId>org.apache.poi</groupId>
  4. <artifactId>poi</artifactId>
  5. <version>RELEASE</version>
  6. </dependency>
  7. <!-- XSSF需要引入的 -->
  8. <dependency>
  9. <groupId>org.apache.xmlbeans</groupId>
  10. <artifactId>xmlbeans</artifactId>
  11. <version>2.6.0</version>
  12. </dependency>
  13. <dependency>
  14. <groupId>dom4j</groupId>
  15. <artifactId>dom4j</artifactId>
  16. <version>1.6.1</version><!--$NO-MVN-MAN-VER$ -->
  17. </dependency>
  18. <dependency>
  19. <groupId>org.apache.poi</groupId>
  20. <artifactId>poi</artifactId>
  21. <version>3.9</version>
  22. </dependency>
  23. <dependency>
  24. <groupId>org.apache.poi</groupId>
  25. <artifactId>poi-ooxml</artifactId>
  26. <version>3.9</version>
  27. </dependency>

3完整代码实例:简单的创建excel,将数据写入excel

依赖导入成功之后,就可以开始进行excel的生成。详细步骤在代码注释中有说明。


  1. /**
  2. * 创建excel
  3. * @param listresult 是需要写入excel中的数据,通过map中的k-v来将数据写入excel
  4. * @return
  5. */
  6. private XSSFWorkbook createUserListExcel(List<Map<String,Object>> listresult){
  7. // 1.创建HSSFWorkbook,一个HSSFWorkbook对应一个Excel文件
  8. XSSFWorkbook wb = new XSSFWorkbook();
  9. // 2.在workbook中添加一个sheet,对应Excel文件中的sheet
  10. XSSFSheet sheet = wb.createSheet("sheet1");
  11. // 3.设置表头,即每个列的列名
  12. String[] titel = {"rowName1","rowName2","rowName3","rowName4"};
  13. // 3.1创建第一行
  14. XSSFRow row = sheet.createRow(0);
  15. // 此处创建一个序号列
  16. row.createCell(0).setCellValue("序号");
  17. // 将列名写入
  18. for (int i = 0; i < titel.length; i++) {
  19. // 给列写入数据,创建单元格,写入数据
  20. row.createCell(i+1).setCellValue(titel[i]);
  21. }
  22. // 写入正式数据
  23. for (int i = 0; i < listresult.size(); i++) {
  24. // 创建行
  25. row = sheet.createRow(i+1);
  26. // 序号
  27. row.createCell(0).setCellValue(i+1);
  28. // 医院名称
  29. row.createCell(1).setCellValue(listresult.get(i).get("rowKey1").toString());
  30. sheet.autoSizeColumn(1, true);
  31. // 业务类型
  32. row.createCell(2).setCellValue(listresult.get(i).get("rowKey2").toString());
  33. // 异常信息
  34. row.createCell(3).setCellValue(listresult.get(i).get("rowKey3").toString());
  35. // 数量
  36. row.createCell(4).setCellValue(listresult.get(i).get("rowKey4").toString());
  37. }
  38. /**
  39. * 上面的操作已经是生成一个完整的文件了,只需要将生成的流转换成文件即可;
  40. * 下面的设置宽度可有可无,对整体影响不大
  41. */
  42. // 设置单元格宽度
  43. int curColWidth = 0;
  44. for (int i = 0; i <= titel.length; i++) {
  45. // 列自适应宽度,对于中文半角不友好,如果列内包含中文需要对包含中文的重新设置。
  46. sheet.autoSizeColumn(i, true);
  47. // 为每一列设置一个最小值,方便中文显示
  48. curColWidth = sheet.getColumnWidth(i);
  49. if(curColWidth<2500){
  50. sheet.setColumnWidth(i, 2500);
  51. }
  52. // 第3列文字较多,设置较大点。
  53. sheet.setColumnWidth(3, 8000);
  54. }
  55. return wb;
  56. }
  57. /**
  58. * 用户列表导出
  59. * @param userForm
  60. */
  61. private String downUserList(List<Map<String,Object>> listresult){
  62. // getTime()是一个返回当前时间的字符串,用于做文件名称
  63. String name = getTime();
  64. // csvFile是我的一个路径,自行设置就行
  65. String ys = csvFile + "//" + name + ".xlsx";
  66. // 1.生成Excel
  67. XSSFWorkbook userListExcel = createUserListExcel(listresult);
  68. try{
  69. // 输出成文件
  70. File file = new File(csvFile);
  71. if(file.exists() || !file.isDirectory()) {
  72. file.mkdirs();
  73. }
  74. // TODO 生成的wb对象传输
  75. FileOutputStream outputStream = new FileOutputStream(new File(ys));
  76. userListExcel.write(outputStream);
  77. outputStream.close();
  78. }catch(Exception e){
  79. e.printStackTrace();
  80. }
  81. return name;
  82. }

因为工作中多次用到了这个,所以简单的记录一下,如有问题,欢迎指正。

点击进入简书地址

点击进入csdn地址

java使用POI将数据导出放入Excel的更多相关文章

  1. Java使用POI实现数据导出excel报表

    Java使用POI实现数据导出excel报表 在上篇文章中,我们简单介绍了java读取word,excel和pdf文档内容 ,但在实际开发中,我们用到最多的是把数据库中数据导出excel报表形式.不仅 ...

  2. 输入三个double型的数据,放入到a,b,c三个变量中去,使用条件结构与交换逻辑将这三个变量中的值从小到大排列。

    import java.util.Scanner; public class C8{ public static void main(String []args){ /* 8.输入三个double型的 ...

  3. 使用POI实现数据导出Excel表格

    package cn.sh.bzt.kwj.action; import java.io.IOException; import java.io.OutputStream; import java.t ...

  4. .NET采集数据,放入数据库总结

    第一次做采集Json的还简单一些但是XML的简直了......... JSON //采集数据 public string GetBetRecordToRepository()//随便你返回什么 { t ...

  5. java使用poi将html导出word,默认打开页面视图

    <html xmlns:v="urn:schemas-microsoft-com:vml" xmlns:o="urn:schemas-microsoft-com:o ...

  6. sql server 数据导出(入)方法总结

    我们都知道日常在面对数据需求时需要导出数据,比较少量的数据导出我们一般是通过查询后另存即可,当面对数据量比较大的时候我们应该怎么处理?我搜索总结一些几个方法:1.bcp 导出.2.数据库本身自带的导入 ...

  7. java 将数据库中的每一条数据取出放入数组或者List中

    1.如何将数据库中数据按照行(即一整条数据)取出来,存入到数组当中? public static String str = null; // 将StringBuffer转化成字符串 public st ...

  8. POI 百万数据导出

    poi 导出主类 package test; import java.io.File; import java.io.FileOutputStream; import java.lang.reflec ...

  9. Java利用POI实现导入导出Excel表格示例代码

    转自:https://www.jb51.net/article/95526.htm 介绍 Jakarta POI 是一套用于访问微软格式文档的Java API.Jakarta POI有很多组件组成,其 ...

随机推荐

  1. c#图像处理入门(-bitmap类和图像像素值获取方法)

    c#图像处理入门 -bitmap类和图像像素值获取方法 一.Bitmap类 Bitmap对象封装了GDI+中的一个位图,此位图由图形图像及其属性的像素数据组成.因此Bitmap是用于处理由像素数据定义 ...

  2. 包建强的培训课程(14):Android与ReactNative

    @import url(http://i.cnblogs.com/Load.ashx?type=style&file=SyntaxHighlighter.css);@import url(/c ...

  3. Dubbo 源码分析 - 集群容错之 Cluster

    1.简介 为了避免单点故障,现在的应用至少会部署在两台服务器上.对于一些负载比较高的服务,会部署更多台服务器.这样,同一环境下的服务提供者数量会大于1.对于服务消费者来说,同一环境下出现了多个服务提供 ...

  4. 编程语言吐槽之Java与C

    包含各种偏见和武断,请谨慎阅读. 为什么在学校学习的C,拿到企业生产中不起作用? 而为什么企业级的程序员,依然对C/C++无法掌控?在算法各方面不够精湛? 根本原因还是应用场景的不同.企业级的开发,主 ...

  5. 「总结」 MLEAutoMaton的各种板子总结

    太菜了,所以咕了,欢迎评论留言... 网络流(不全) 自适应Simpson

  6. Java程序员的成长之路

    阅读本文大概需要 8.2 分钟. tips:虽然题目是写的Java程序员,但对其他语言的开发来说也会有借鉴作用. 本篇介绍的是大体思路,以及每个节点所需要学习的书籍内容,如果大家对详细的技术点有需要, ...

  7. java IO流之详细总结

    什么是io流? 分为两种: 输入流:可以从文件中读取到程序,从源数据源读取到程序,叫做输入流. 输出流:可以从程序中读取到文件,从程序写,使用输出流,写入到文件中.叫做输出流. 使用File操作文件或 ...

  8. 数据库占用cpu较高的查询

    近来看到别人的有关数据库查询cpu占用较高的sql语句(本人sql并不好),所以查询了一下资料,记录一下,便于理解和应用. 首先,将语句贴在这里 SELECT TOP 10 --平均cpu时间 tot ...

  9. python自动化工具之pywinauto(一个实例)结合pyuserinput

    以下是pywinauto使用指南.这个窗口句柄可以在Spy++中查看 (Microsoft Spy++(查看窗口句柄) 10.00.30319 官方最新绿色版) python自动化工具之pywinau ...

  10. 一次Linux自动化部署尝试

    最近做一个项目临近测试,购买的是阿里云的服务器,每次部署都是手动打包war,然后上传到服务器,然后修改配置文件,不仅繁琐,而且费时,就思索着找一个一键式的部署方式,今天终于腾出时间来做这件事,记录一下 ...