当前位置: 首页 > news >正文

导航网站前端模板网页设计培训

导航网站前端模板,网页设计培训,网站建设策划书论文,独立外贸网站建设在Spring Boot项目中导出复杂对象到Excel文件&#xff0c;可以利用Hutool或EasyExcel等库来简化操作。这里我们将详细介绍如何使用Hutool和EasyExcel两种方式来实现这一功能。 使用Hutool导出复杂对象到Excel 首先确保你的pom.xml中添加了Hutool的依赖&#xff1a; <depe…

在Spring Boot项目中导出复杂对象到Excel文件,可以利用Hutool或EasyExcel等库来简化操作。这里我们将详细介绍如何使用Hutool和EasyExcel两种方式来实现这一功能。

使用Hutool导出复杂对象到Excel

首先确保你的pom.xml中添加了Hutool的依赖:

<dependency><groupId>cn.hutool</groupId><artifactId>hutool-all</artifactId><version>5.8.10</version> <!-- 请根据实际情况选择最新版本 -->
</dependency>

接下来是一个简单的示例,展示如何导出一个包含复杂对象的列表到Excel文件。

示例代码

假设我们有一个User类,它包含一个嵌套的Address对象。

import cn.hutool.poi.excel.ExcelUtil;
import cn.hutool.poi.excel.ExcelWriter;import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;import javax.servlet.ServletOutputStream;
import javax.servlet.http.HttpServletResponse;
import java.io.IOException;
import java.net.URLEncoder;
import java.util.ArrayList;
import java.util.List;
import java.util.Map;
import java.util.stream.Collectors;@RestController
@RequestMapping("/api")
public class UserController {@GetMapping("/exportUsers")public void exportUsers(HttpServletResponse response) throws IOException {// 模拟获取用户数据List<User> users = getUsers();// 创建ExcelWriter实例ExcelWriter writer = ExcelUtil.getWriter(true); // true表示自动创建表头// 将复杂对象转换为Map列表,方便写入ExcelList<Map<String, Object>> dataList = users.stream().map(user -> {Map<String, Object> row = new HashMap<>();row.put("ID", user.getId());row.put("姓名", user.getName());row.put("邮箱", user.getEmail());row.put("年龄", user.getAge());row.put("城市", user.getAddress().getCity());row.put("街道", user.getAddress().getStreet());return row;}).collect(Collectors.toList());// 写入数据writer.write(dataList, true);// 设置响应内容类型和头部信息response.setContentType("application/vnd.ms-excel;charset=utf-8");String fileName = URLEncoder.encode("用户列表", "UTF-8");response.setHeader("Content-Disposition", "attachment;filename=" + fileName + ".xlsx");// 将输出流写入responseServletOutputStream out = response.getOutputStream();writer.flush(out, true);out.close();writer.close();}private List<User> getUsers() {List<User> users = new ArrayList<>();Address address = new Address("北京", "中关村大街");users.add(new User(1L, "张三", "zhangsan@example.com", 28, address));return users;}
}class User {private Long id;private String name;private String email;private Integer age;private Address address;public User(Long id, String name, String email, Integer age, Address address) {this.id = id;this.name = name;this.email = email;this.age = age;this.address = address;}// getter和setter方法
}class Address {private String city;private String street;public Address(String city, String street) {this.city = city;this.street = street;}// getter和setter方法
}

使用EasyExcel导出复杂对象到Excel

EasyExcel是阿里巴巴开源的一个非常高效的Excel处理库,特别适合处理大数据量的Excel文件。首先,在pom.xml中添加EasyExcel的依赖:

<dependency><groupId>com.alibaba</groupId><artifactId>easyexcel</artifactId><version>2.2.10</version> <!-- 请根据实际情况选择最新版本 -->
</dependency>

接下来是一个使用EasyExcel导出复杂对象的例子。

示例代码

假设我们仍然使用上面提到的UserAddress类。

import com.alibaba.excel.EasyExcel;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;import javax.servlet.http.HttpServletResponse;
import java.io.IOException;
import java.net.URLEncoder;
import java.util.ArrayList;
import java.util.List;@RestController
@RequestMapping("/api")
public class EasyExcelController {@GetMapping("/exportUsers")public void exportUsers(HttpServletResponse response) throws IOException {// 模拟获取用户数据List<User> users = getUsers();// 设置响应内容类型和头部信息response.setContentType("application/vnd.ms-excel;charset=utf-8");String fileName = URLEncoder.encode("用户列表", "UTF-8");response.setHeader("Content-Disposition", "attachment;filename=" + fileName + ".xlsx");// 使用EasyExcel写出数据到输出流EasyExcel.write(response.getOutputStream(), UserData.class).sheet("用户信息").doWrite(users);}private List<User> getUsers() {List<User> users = new ArrayList<>();Address address = new Address("北京", "中关村大街");users.add(new User(1L, "张三", "zhangsan@example.com", 28, address));return users;}
}// 数据实体类
class UserData {@com.alibaba.excel.annotation.ExcelProperty("ID")private Long id;@com.alibaba.excel.annotation.ExcelProperty("姓名")private String name;@com.alibaba.excel.annotation.ExcelProperty("邮箱")private String email;@com.alibaba.excel.annotation.ExcelProperty("年龄")private Integer age;@com.alibaba.excel.annotation.ExcelProperty("城市")private String city;@com.alibaba.excel.annotation.ExcelProperty("街道")private String street;// 构造函数、getter和setter方法public UserData(User user) {this.id = user.getId();this.name = user.getName();this.email = user.getEmail();this.age = user.getAge();this.city = user.getAddress().getCity();this.street = user.getAddress().getStreet();}// getter和setter方法
}

在这个例子中,我们定义了一个UserData类来映射User对象的数据,并使用EasyExcel将这些数据写入Excel文件。

通过上述方法,你可以轻松地在Spring Boot项目中导出复杂对象到Excel文件。无论是使用Hutool还是EasyExcel,都可以有效地简化Excel处理的工作。

http://www.hrbkazy.com/news/17064.html

相关文章:

  • 东单网站建设优化营商环境评价
  • 做网站买域名推广网站源码
  • 平度做网站推广免费拓客软件排行榜
  • wordpress图床插件郑州百度网站优化排名
  • 百度站长如何添加网站网址安全中心检测
  • php mysql做网站电商运营培训班多少钱
  • 沧州做网站推广公司东莞网站建设推广技巧
  • 街舞舞团公司做网站排名优化服务
  • 石狮新站seo所有代刷平台推广
  • flash网站banner制作教程怎么样做一个自己的网站
  • 西安做网站找腾帆竞价托管推广
  • 网站优化url层级怎么做公众号seo排名
  • 网站设计报价百度网页高级搜索
  • 威客网站系统关键词搜索
  • 丰台做网站公司营销推广怎么做
  • 私人兼职做网站开发培训学校网站
  • 业余学做衣服上哪个网站网站营销策略有哪些
  • 罗田做网站网络推广都有哪些平台
  • 做网站建设最好的公司是自媒体怎么做
  • 佛山市网站建设最新域名ip地址
  • 东营做网站tt0546徐州百度快照优化
  • 做网站 备案成人培训班有哪些课程
  • 网站建设运营公司推荐合肥疫情最新消息
  • 公众号运营策划seo整站优化报价
  • 新开传奇seo综合查询工具
  • 招聘网站建设及推广七台河网站seo
  • 招商网站怎么做营销推广方式
  • 公司做社交网站诈骗99个创意营销方案
  • 学生管理系统网站免费友情链接网
  • 免费建手机个人网站百度seo灰色词排名代发