java导出excel表格

java导出excel(easyexcel方式)

1.maven的pom.xml文件中引入com.alibaba.easyexcel
		<dependency>
            <groupId>com.alibaba</groupId>
            <artifactId>easyexcel</artifactId>
            <!--根据实际需求引用对应版本-->
            <version>3.1.1</version>
        </dependency>
2. 导出结果实体类
/**
 * 导出用户返回VO对象
 * 
 */
@Data
public class UserExportListRes {

    
    @ExcelProperty("名称")
    private String name;

    @ExcelProperty("性别")
    private String sex;
    
	@ExcelProperty("年龄")
    private String age;
}

使用@ExcelProperty注解,标明导出excel表头名称

3. controller代码
@RestController
@RequestMapping(value = "/user", produces = MediaType.APPLICATION_JSON_UTF8_VALUE)
public class UserController {
	@Autowired
    private UserService userService;
	/**
     * 导出用户列表
     * @param param 查询请求参数,根据业务需求定义,如果不需要查询即无需此参数
     * @return
     */
    @PostMapping(value = "/export")
    public void export(HttpServletResponse response,  @RequestBody userReq param){
        userService.export(response, param);
    }
}
4.service与service实现类代码

4.1 service代码:

public interface UserService{
	/**
     * 导出excel
     * @param response 
     * @param param 请求参数
     * @return
     */
	void export(HttpServletResponse response, QueryUserListReq param);
}

4.2 service实现类代码:

@Slf4j
@Service
public class UserServiceImpl implements UserService {
 	@Override
    public void export(HttpServletResponse response, QueryUserListReq param) {
        String fileName = "";
        try {
            // 设置响应头
            response.setContentType("application/vnd.ms-excel");
            response.setCharacterEncoding("utf-8");
            fileName = URLEncoder.encode("用户信息.xlsx", "UTF-8").replaceAll("\\+", "%20");
            response.setHeader("Content-disposition", "attachment;filename*=UTF-8''" + fileName);
         } catch (Exception e) {
            e.printStackTrace();
        }
        try (ServletOutputStream outputStream = response.getOutputStream()) {
            //todo 业务数据逻辑处理
            List<UserExportListRes> userExportListResList = new ArrayList<>();
            UserExportListRes userExportListRes = new UserExportListRes();
            userExportListRes.setName("张三");
            userExportListRes.setSex("男");
            userExportListRes.setAge("18");
            userExportListResList.add(userExportListRes);
            UserExportListRes userExportListRes2 = new UserExportListRes();
            userExportListRes2.setName("小红");
            userExportListRes2.setSex("女");
            userExportListRes2.setAge("18");
            userExportListResList.add(userExportListRes2);
            EasyExcel.write(outputStream, UserExportListRes.class)
                    .sheet("用户信息")
                    .doWrite(userExportListResList);
            outputStream.flush();
        } catch (Exception e) {
            e.printStackTrace();
            log.error("生成下载动态模板异常!", e);
        }
    }
}

EasyExcel.write将数据流与实体类的class写入,.sheet(“用户信息”)即设置导出文件sheet名称;.doWrite(userExportListResList)即写入需要导出的业务数据

5. 总结

使用com.alibaba.easyexcel可以快速, 简洁实现java导出简单的excel表格信息,如果需要具体格式话导出的excel样式,需根据以上内容深入研究如何设置excel格式。
以上内容,仅供各位兄弟姐妹参考,如发现问题,请各位多提出宝贵意见。

  • 15
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论
以下是使用Java导出Excel表格的示例代码: ```java import java.io.FileOutputStream; import java.io.IOException; import java.util.ArrayList; import java.util.List; import org.apache.poi.ss.usermodel.Cell; import org.apache.poi.ss.usermodel.Row; import org.apache.poi.ss.usermodel.Sheet; import org.apache.poi.ss.usermodel.Workbook; import org.apache.poi.xssf.usermodel.XSSFWorkbook; public class ExportExcelExample { public static void main(String[] args) { // 创建工作簿 Workbook workbook = new XSSFWorkbook(); // 创建工作表 Sheet sheet = workbook.createSheet("Sheet1"); // 创建表头 Row headerRow = sheet.createRow(0); Cell headerCell1 = headerRow.createCell(0); headerCell1.setCellValue("姓名"); Cell headerCell2 = headerRow.createCell(1); headerCell2.setCellValue("年龄"); Cell headerCell3 = headerRow.createCell(2); headerCell3.setCellValue("性别"); // 填充数据 List<Person> personList = new ArrayList<>(); personList.add(new Person("张三", 20, "男")); personList.add(new Person("李四", 25, "女")); personList.add(new Person("王五", 30, "男")); int rowIndex = 1; for (Person person : personList) { Row dataRow = sheet.createRow(rowIndex++); Cell dataCell1 = dataRow.createCell(0); dataCell1.setCellValue(person.getName()); Cell dataCell2 = dataRow.createCell(1); dataCell2.setCellValue(person.getAge()); Cell dataCell3 = dataRow.createCell(2); dataCell3.setCellValue(person.getGender()); } // 导出Excel文件 try (FileOutputStream outputStream = new FileOutputStream("person.xlsx")) { workbook.write(outputStream); } catch (IOException e) { e.printStackTrace(); } } } class Person { private String name; private int age; private String gender; public Person(String name, int age, String gender) { this.name = name; this.age = age; this.gender = gender; } public String getName() { return name; } public int getAge() { return age; } public String getGender() { return gender; } } ``` 这个示例代码创建了一个包含表头和数据的Excel表格,并将其导出到名为“person.xlsx”的文件中。你可以根据需要修改表格的内容和文件名。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

笑对&人生

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值