Spring Boot导出EXCEL 文件

主要功能:实现java导出excel到本地

JDK版本:openJDK 20.0.1

依赖pom.xml

<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 https://maven.apache.org/xsd/maven-4.0.0.xsd"><modelVersion>4.0.0</modelVersion><parent><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-parent</artifactId><version>3.2.2</version><relativePath/> <!-- lookup parent from repository --></parent><groupId>com.joker</groupId><artifactId>export</artifactId><version>0.0.1-SNAPSHOT</version><name>export</name><description>export</description><properties><java.version>17</java.version></properties><dependencies><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-web</artifactId></dependency><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-devtools</artifactId><scope>runtime</scope><optional>true</optional></dependency><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-test</artifactId><scope>test</scope></dependency><dependency><groupId>cn.afterturn</groupId><artifactId>easypoi-base</artifactId><version>4.1.0</version></dependency><dependency><groupId>cn.afterturn</groupId><artifactId>easypoi-web</artifactId><version>4.1.0</version></dependency><dependency><groupId>cn.afterturn</groupId><artifactId>easypoi-annotation</artifactId><version>4.1.0</version></dependency></dependencies><build><plugins><plugin><groupId>org.springframework.boot</groupId><artifactId>spring-boot-maven-plugin</artifactId></plugin></plugins></build></project>

主要核心代码

package com.joker.export.Controller;import com.fasterxml.jackson.core.type.TypeReference;
import com.fasterxml.jackson.core.JsonProcessingException;
import com.fasterxml.jackson.databind.ObjectMapper;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;import com.fasterxml.jackson.databind.ObjectMapper;
import org.apache.poi.ss.usermodel.*;
import org.apache.poi.xssf.usermodel.XSSFWorkbook;import java.io.*;
import java.util.Iterator;
import java.util.List;import java.util.Map;@RestController
public class ExportExcelController {@RequestMapping("/")public String home(){System.out.println("hello world");return "Hello World for Spring Boot by Joker!";}@RequestMapping("/Export2Excel")public String Export2Excel() throws IOException {// you should get the filename from the input dataString filename = "ExportDataByJoker"  +".xlsx";// Parse the JSON string into a JSON object.String jsonData = "[{\"ZHC_ZZ\":\"20001118\",\"ZHR_ID_JD\":\"20001118\",\"ZHC_ZZ_DESC\":\"\",\"ZHC_ZZ_LEVEL\":\"21\",\"ZHC_ZZ_LEVEL_DESC\":\"二级部门\",\"ZHC_PLAN\":0,\"ZHC_PLAN_ACTUAL\":0,\"ZHC_PLAN_AVAILABLE_AC\":0,\"ZHC_PLAN_RATE\":0.0000,\"ZHC_PLAN_RATE_CHAR\":\"\",\"ZHC_PLAN_LOCK\":0,\"ZHC_PLAN_RELEASE\":0,\"ZHC_PLAN_AVAILABLE_AD\":0,\"ZHC_FREEZE\":\"\",\"ZORG_FULLNAME\":\"\"},{\"ZHC_ZZ\":\"20001342\",\"ZHR_ID_JD\":\"20001342\",\"ZHC_ZZ_DESC\":\"测试组织20230915\",\"ZHC_ZZ_LEVEL\":\"21\",\"ZHC_ZZ_LEVEL_DESC\":\"二级部门\",\"ZHC_PLAN\":0,\"ZHC_PLAN_ACTUAL\":0,\"ZHC_PLAN_AVAILABLE_AC\":0,\"ZHC_PLAN_RATE\":0.0000,\"ZHC_PLAN_RATE_CHAR\":\"\",\"ZHC_PLAN_LOCK\":0,\"ZHC_PLAN_RELEASE\":0,\"ZHC_PLAN_AVAILABLE_AD\":0,\"ZHC_FREEZE\":\"\",\"ZORG_FULLNAME\":\"华中区\\/测试组织20230915\"},{\"ZHC_ZZ\":\"10000127\",\"ZHR_ID_JD\":\"01010603\",\"ZHC_ZZ_DESC\":\"长沙区\",\"ZHC_ZZ_LEVEL\":\"21\",\"ZHC_ZZ_LEVEL_DESC\":\"二级部门\",\"ZHC_PLAN\":0,\"ZHC_PLAN_ACTUAL\":374,\"ZHC_PLAN_AVAILABLE_AC\":-374,\"ZHC_PLAN_RATE\":0.0000,\"ZHC_PLAN_RATE_CHAR\":\"\",\"ZHC_PLAN_LOCK\":0,\"ZHC_PLAN_RELEASE\":2,\"ZHC_PLAN_AVAILABLE_AD\":-372,\"ZHC_FREEZE\":\"\",\"ZORG_FULLNAME\":\"华中区\\/长沙区\"},{\"ZHC_ZZ\":\"10006019\",\"ZHR_ID_JD\":\"0154\",\"ZHC_ZZ_DESC\":\"南昌区\",\"ZHC_ZZ_LEVEL\":\"21\",\"ZHC_ZZ_LEVEL_DESC\":\"二级部门\",\"ZHC_PLAN\":0,\"ZHC_PLAN_ACTUAL\":2,\"ZHC_PLAN_AVAILABLE_AC\":-2,\"ZHC_PLAN_RATE\":0.0000,\"ZHC_PLAN_RATE_CHAR\":\"\",\"ZHC_PLAN_LOCK\":0,\"ZHC_PLAN_RELEASE\":1,\"ZHC_PLAN_AVAILABLE_AD\":-1,\"ZHC_FREEZE\":\"\",\"ZORG_FULLNAME\":\"华中区\\/南昌区\"},{\"ZHC_ZZ\":\"10000009\",\"ZHR_ID_JD\":\"01010602\",\"ZHC_ZZ_DESC\":\"武汉区\",\"ZHC_ZZ_LEVEL\":\"21\",\"ZHC_ZZ_LEVEL_DESC\":\"二级部门\",\"ZHC_PLAN\":0,\"ZHC_PLAN_ACTUAL\":333,\"ZHC_PLAN_AVAILABLE_AC\":-333,\"ZHC_PLAN_RATE\":0.0000,\"ZHC_PLAN_RATE_CHAR\":\"\",\"ZHC_PLAN_LOCK\":0,\"ZHC_PLAN_RELEASE\":3,\"ZHC_PLAN_AVAILABLE_AD\":-330,\"ZHC_FREEZE\":\"\",\"ZORG_FULLNAME\":\"华中区\\/武汉区\"},{\"ZHC_ZZ\":\"20000365\",\"ZHR_ID_JD\":\"20000365\",\"ZHC_ZZ_DESC\":\"电商部\",\"ZHC_ZZ_LEVEL\":\"21\",\"ZHC_ZZ_LEVEL_DESC\":\"二级部门\",\"ZHC_PLAN\":0,\"ZHC_PLAN_ACTUAL\":36,\"ZHC_PLAN_AVAILABLE_AC\":-36,\"ZHC_PLAN_RATE\":0.0000,\"ZHC_PLAN_RATE_CHAR\":\"\",\"ZHC_PLAN_LOCK\":0,\"ZHC_PLAN_RELEASE\":0,\"ZHC_PLAN_AVAILABLE_AD\":-36,\"ZHC_FREEZE\":\"\",\"ZORG_FULLNAME\":\"华中区\\/电商部\"},{\"ZHC_ZZ\":\"20000366\",\"ZHR_ID_JD\":\"20000366\",\"ZHC_ZZ_DESC\":\"业务支持部\",\"ZHC_ZZ_LEVEL\":\"21\",\"ZHC_ZZ_LEVEL_DESC\":\"二级部门\",\"ZHC_PLAN\":0,\"ZHC_PLAN_ACTUAL\":28,\"ZHC_PLAN_AVAILABLE_AC\":-28,\"ZHC_PLAN_RATE\":0.0000,\"ZHC_PLAN_RATE_CHAR\":\"\",\"ZHC_PLAN_LOCK\":0,\"ZHC_PLAN_RELEASE\":1,\"ZHC_PLAN_AVAILABLE_AD\":-27,\"ZHC_FREEZE\":\"\",\"ZORG_FULLNAME\":\"华中区\\/业务支持部\"},{\"ZHC_ZZ\":\"20000367\",\"ZHR_ID_JD\":\"20000367\",\"ZHC_ZZ_DESC\":\"市场品牌部\",\"ZHC_ZZ_LEVEL\":\"21\",\"ZHC_ZZ_LEVEL_DESC\":\"二级部门\",\"ZHC_PLAN\":0,\"ZHC_PLAN_ACTUAL\":15,\"ZHC_PLAN_AVAILABLE_AC\":-15,\"ZHC_PLAN_RATE\":0.0000,\"ZHC_PLAN_RATE_CHAR\":\"\",\"ZHC_PLAN_LOCK\":0,\"ZHC_PLAN_RELEASE\":0,\"ZHC_PLAN_AVAILABLE_AD\":-15,\"ZHC_FREEZE\":\"\",\"ZORG_FULLNAME\":\"华中区\\/市场品牌部\"},{\"ZHC_ZZ\":\"20000559\",\"ZHR_ID_JD\":\"20000559\",\"ZHC_ZZ_DESC\":\"成本中心测试\",\"ZHC_ZZ_LEVEL\":\"21\",\"ZHC_ZZ_LEVEL_DESC\":\"二级部门\",\"ZHC_PLAN\":0,\"ZHC_PLAN_ACTUAL\":0,\"ZHC_PLAN_AVAILABLE_AC\":0,\"ZHC_PLAN_RATE\":0.0000,\"ZHC_PLAN_RATE_CHAR\":\"\",\"ZHC_PLAN_LOCK\":0,\"ZHC_PLAN_RELEASE\":0,\"ZHC_PLAN_AVAILABLE_AD\":0,\"ZHC_FREEZE\":\"\",\"ZORG_FULLNAME\":\"华中区\\/成本中心测试\"}]";// Convert JSON to a list of mapsObjectMapper mapper = new ObjectMapper();List<Map<String, Object>> dataList = mapper.readValue(jsonData, new TypeReference<List<Map<String, Object>>>() {});// Create an Excel workbookWorkbook workbook = new XSSFWorkbook();// Create a sheetSheet sheet = workbook.createSheet("Sheet1");// Create a header rowRow headerRow = sheet.createRow(0);// Get the column names from the first map entry,// get the column names from the input data is betterMap<String, Object> firstData = dataList.get(0);Iterator<Map.Entry<String, Object>> iterator = firstData.entrySet().iterator();int columnCount = 0;while (iterator.hasNext()) {Map.Entry<String, Object> entry = iterator.next();String columnName = entry.getKey();headerRow.createCell(columnCount).setCellValue(columnName);columnCount++;}// Create data rowsint rowIndex = 1;for (Map<String, Object> data : dataList) {Row dataRow = sheet.createRow(rowIndex);int dataColumnCount = 0;for (Map.Entry<String, Object> entry : data.entrySet()) {Object value = entry.getValue();Cell cell = dataRow.createCell(dataColumnCount);if (value instanceof String) {cell.setCellValue((String) value);} else if (value instanceof Number) {cell.setCellValue(((Number) value).doubleValue());} else {cell.setCellValue(value.toString());}dataColumnCount++;}rowIndex++;}// Auto-size the columnsfor (int i = 0; i < columnCount; i++) {sheet.autoSizeColumn(i);}// Write the workbook to a filetry (FileOutputStream out = new FileOutputStream(filename)) {workbook.write(out);}// change the return to file streamreturn "download file is ready";}
}

执行效果:
在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/655237.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Java 面试题之 IO(一)

字节流 文章目录 字节流InputStream&#xff08;字节输入流&#xff09;OutputStream&#xff08;字节输出流&#xff09; 文章来自Java Guide 用于学习如有侵权&#xff0c;立即删除 InputStream&#xff08;字节输入流&#xff09; InputStream用于从源头&#xff08;通常是…

Centos Cron设置定时任务

这本是很简单的问题&#xff0c;但是我服务器重装系统两次&#xff0c;遇到的问题都不一样&#xff0c;所以记录一下 1.首先要确保服务器上有 cron 服务 sudo systemctl status crond2.设置时区 sudo timedatectl set-timezone Asia/Shanghai3.重启crond 服务使crond服务的时…

Xds (eXtensible Discovery Service)理解

Xds &#xff08;eXtensible Discovery Service&#xff09;理解 概念介绍 XDS&#xff1a;全称是 eXtensible Discovery Service&#xff0c;中文译为”可扩展的服务发现“。是一个扩展性的协议&#xff0c;可以用于配置和控制 Envoy 代理的各个方面&#xff0c;包括路由规则…

Leetcode 206 反转链表

反转链表 准备工作1&#xff09;ListNode基本结构2&#xff09;初始化ListNode集合 解法一&#xff1a;遍历创建新节点解法二&#xff1a;两组List&#xff0c;面向对象操作解法三&#xff1a;递归调用解法四&#xff1a;直接移动解法五&#xff1a;解法二的面向过程 Leetcode …

从c到c++——6:auto

在编写c程序时&#xff0c;需要在初始化变量时清楚地知道该变量的数据类型&#xff0c;有时这到这一点并不容易&#xff0c;在涉及到函数指针&#xff0c;多级指针时往往很难一下子给出准确的值。使用auto关键字很好的提高编程效率。 auto关键字会根据右边的类型自动生成适合的…

如何编写.gitignore文件

文章目录 前端架构师教你如何编写.gitignore文件.gitignore文件简介.gitignore文件的语法规则.gitignore文件的最佳实践常见问题与解决 前端架构师教你如何编写.gitignore文件 .gitignore文件简介 .gitignore文件是Git版本控制系统中一个非常有用的工具。它可以指定一组文件或…

Ubuntu 20.04 Server 使用命令行设置 IP 地址

1、编辑 /etc/netplan/ 目录下的配置文件00-installer-config.yaml (修改之前&#xff0c;把原来的文件备份) 按照对应的配置进行修改IP地址和网关 2、运行命令使其生效 sudo netplan apply 修改完成后&#xff0c;永久有效。重启后配置不会丢失

数据分析中需要用的的python知识(包括Numpy、Pandas、Matplotlib)

由于python的基础知识比较琐碎&#xff0c;这一块我打算以知识导图的形式呈现 软件&#xff1a;幕布 参考内容&#xff1a;菜菜菊花酱数据分析 python基础知识&#xff1a;https://www.mubu.com/doc/5uLBgn5LNTI numpy&#xff1a;https://www.mubu.com/doc/SgpdGGHMvI Pandas&…

2024年Java算法面试题

2024年Java实战面试题&#xff08;北京&#xff09;_java 5 年 面试-CSDN博客 一、波菲那契递归 System.out.println("banc " banc(10)) public static int banc(int n){if( n0 ){return 0;}else if( n1 ){return 1;}else{return banc(n-1) banc(n-2);} } 二、冒…

【智能家居入门之微信小程序控制下位机】(STM32、ONENET云平台、微信小程序、HTTP协议)

实现微信小程序控制单片机外设动作 一、使用ONENET可视化组件控制单片机外设动作二、使用微信小程序控制单片机外设动作三、总结 本篇博客话接上文&#xff1a; https://blog.csdn.net/m0_71523511/article/details/135892908 上一篇博客实现了微信小程序接收单片机上传的数据…

R语言【taxlist】——summary(),show(),print():打印taxlist对象及其内容的概述

Package taxlist version 0.2.4 Description 一种方法&#xff0c;用于显示 taxlist 对象内容的概述或所选分类组的概述。 Usage ## S4 method for signature taxlist summary(object,ConceptID,units "Kb",check_validity TRUE,display "both",maxs…

三、防御保护---防火墙安全策略篇

三、防御保护---防火墙安全策略篇 一、什么是安全策略二、安全策略的组成1.匹配条件2.动作3.策略标识 三、防火墙的状态检测和会话表1.会话表2.状态检测技术 四、ASPF--隐形通道五、用户认证1.用户认证的分类2.认证方式3.认证策略4.认证域 一、什么是安全策略 传统的包过滤防火…

Mysql 更新数据

MySQL中使用UPDATE语句更新表中的记录&#xff0c;可以更新特定的行或者同时更新所有的行。基本语法结构如下&#xff1a; UPDATE table_name SET column_name1 value1,column_name2 value2,……, column_namen valuen WHERE(condition); column_name1,column_name2,……,…

mcu专用看门狗复位芯片(如MAX706)

mcu专用看门狗复位芯片&#xff08;如MAX706&#xff09; 为什么要使用电压复位芯片RESET引脚WDO引脚MR引脚WDI引脚 国产替代型号应用电路1 推荐电路&#xff08;用一个跳线帽使能/关闭看门狗功能&#xff0c;调试MCU时防止看门狗芯片随便触发复位功能&#xff09;&#xff0c;…

字符串函数自实现

1.strlen size_t strlen(const char *s);返回字符个数&#xff08;不包含结尾\0&#xff09; #include<stdio.h> #include<string.h>int mystr(const char* s) {int cnt 0;int index 0;while(s[index] ! \0){index;cnt;}return cnt; } int main() {char s[] &…

智能时代:自然语言生成SQL与知识图谱问答实战

语义解析 前言语义解析的应用场景总结概论语义解析和大模型的关系延伸阅读 前言 语义解析技术可以提高人机交互的效率和准确性&#xff0c;在自然语言处理、数据分析、智能客服、智能家居等领域都有广泛的应用前景。特别是在大数据时代&#xff0c;语义解析能够帮助企业更快速…

Unity中使用Ultraleap的InteractionButton组件

本节在上一节基础上进行&#xff0c;上一小结参考如下&#xff1a; Unity中创建Ultraleap 3Di交互项目 本节工程文件如下&#xff1a; Unity中使用Ultraleap的InteractionButton组件 本节结构有所更改&#xff0c;主要是参考官方示例结构进行重新调整&#xff0c;和上一小节相…

定时任务的corn表达式简要介绍

corn表达式的各项从左到右依次为&#xff1a;corn&#xff1a;秒 分钟 小时 日期 月份 星期几 年份 秒&#xff1a;0-59 分钟&#xff1a;0-59 小时&#xff1a;0-23 日期&#xff1a;1-31 月份&#xff1a;1-12 或 JAN-DEC 星期几&#xff1a;0-6 或 SUN-SAT 年份&#xff1a…

使用Process.Start()打开文件夹时出现访问被拒绝异常

默认的打开形式 Process.Start(folderPath); 解决方案 System.Diagnostics.Process.Start(Environment.GetEnvironmentVariable("WINDIR") "\explorer.exe", folderPath); 参考文献 c# - 使用 Process.Start() 打开文件夹时访问被拒绝异常 - IT工具网…

asp.net core接口报500错误排查

接口已经进行了try catch捕捉&#xff0c;但是还是报错&#xff0c;放到web.config下的错误&#xff0c;主要是是将stdoutLogEnabled修改为true <aspNetCore processPath"dotnet" arguments".\xxxx.dll" stdoutLogEnabled"true" stdoutLogFil…