​ 文件导出

简介: ​文件导出


文件导出
1、Apache POI的maven坐标


org.apache.poi
poi
3.16


org.apache.poi
poi-ooxml
3.16

2、Controller层

package com.zsh.controller;

import com.zsh.service.UserService;
import org.springframework.beans.factory.annotation.Autowired;
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;

@RequestMapping("/user")
@RestController
public class UserController {

@Autowired
private UserService userService;

/**
 * 导出7天的报表数据
 * @param response
 */
@GetMapping("/export")
public void export(HttpServletResponse response){
    userService.export(response);
}

}

3、Service层

package com.zsh.service;

import com.baomidou.mybatisplus.extension.service.IService;
import com.zsh.pojo.User;

import javax.servlet.http.HttpServletResponse;

public interface UserService extends IService {
void export(HttpServletResponse response);
}
4、拷贝模板

将报表模板.xlsx拷贝到项目的resources/template目录中

5、ServiceImpl

package com.zsh.service.impl;

import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
import com.zsh.mapper.UserMapper;
import com.zsh.pojo.User;
import com.zsh.pojo.UserVO;
import com.zsh.service.UserService;
import org.apache.poi.xssf.usermodel.XSSFRow;
import org.apache.poi.xssf.usermodel.XSSFSheet;
import org.apache.poi.xssf.usermodel.XSSFWorkbook;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;

import javax.servlet.ServletOutputStream;
import javax.servlet.http.HttpServletResponse;
import java.io.IOException;
import java.io.InputStream;
import java.net.URLEncoder;
import java.nio.charset.StandardCharsets;
import java.time.LocalDate;
import java.time.LocalDateTime;
import java.time.LocalTime;
import java.util.List;

@Service
public class UserServiceImpl extends ServiceImpl implements UserService {

@Autowired
private UserMapper userMapper;

@Override
public void export(HttpServletResponse response) {
    // 获取前七天的起止日期
    // 假设今天是2023-12-31  [begin:2023-12-23    end:2023-12-30]
    LocalDate begin = LocalDate.now().minusDays(7);
    LocalDate end = LocalDate.now().minusDays(1);

    // 获取开始的最早时间和结束的最晚时间
    LocalDateTime beginTime = LocalDateTime.of(begin, LocalTime.MIN);
    LocalDateTime endTime = LocalDateTime.of(end, LocalTime.MAX);

    // 查询日期范围内的数据
    List<UserVO> userList =  userMapper.selectTime(beginTime,endTime);

    // 设置HTTP相应的MIME类型,指定Excel
    response.setContentType("application/vnd.openxmlformats-officedocument.spreadsheetml.sheet");
    // 通知浏览器以附件的姓氏下载文件,并告知文件名称,设置URLEncoder保存时不乱码
    response.setHeader("Content-Disposition", "attachment; filename=" + URLEncoder.encode("开朗觉觉.xlsx", StandardCharsets.UTF_8));

    // 填充数据到报表中
    InputStream xlsx = this.getClass().getClassLoader().getResourceAsStream("xlsx\\开朗觉觉.xlsx");

    try {
        // 创建工作簿
        XSSFWorkbook excel = new XSSFWorkbook(xlsx);

        // 获得Excel文件中的Sheet页
        XSSFSheet sheet1 = excel.getSheet("Sheet1");

        // 获取学生总数第一行(因为第一行已存在,所以直接获取)
        XSSFRow row1 = sheet1.getRow(0);

        // 获取第3个单元格(因为这个单元格不存在,所以创建单元格)
        row1.createCell(5).setCellValue(userList.size());  // 学生总数
        System.out.println(userList.size());
        // 循环打印每一天进班的学生(当前算的7天的)
        for (int i = 0; i < 7;i++){
            // 获取当天的时间
            LocalDate date = begin.plusDays(i);

            // 获取当天最小时间和最大时间的时分秒
            beginTime = LocalDateTime.of(date, LocalTime.MIN);
            endTime = LocalDateTime.of(date, LocalTime.MAX);

            // 准备当天的数据
            userList = userMapper.selectTime(beginTime, endTime);

            // 获取要添加数据的行数(每循环一次获取下一行)
            XSSFRow rown = sheet1.createRow(2 + i);

            // 因为查询到的结果在集合中,所以要遍历获取
            for (UserVO userVO : userList) {
                // 设置第一个单元格的值(入学时间)
                rown.createCell(0).setCellValue(date.toString());

                // 设置第二个单元格的值(id)
                rown.createCell(1).setCellValue(userVO.getId());

                // 设置第三个单元格的值(姓名)
                rown.createCell(2).setCellValue(userVO.getName());

                // 设置第四个单元格的值(年龄)
                rown.createCell(3).setCellValue(userVO.getAge());

            }
        }
        // 通过输出流文件下载到客户浏览器中
        ServletOutputStream out = response.getOutputStream();
        excel.write(out);

        //关闭资源
        out.flush();
        excel.close();
        out.close();
    } catch (IOException e) {
        throw new RuntimeException(e);
    }
}

}
6、Mapper

package com.zsh.mapper;

@Mapper
public interface UserMapper extends BaseMapper {

List<UserVO> selectTime(LocalDateTime beginTime, LocalDateTime endTime);

}
7、Mapper.xml

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd" >

<select id="selectTime" resultType="com.zsh.pojo.UserVO">
    select * from user where date_time between #{beginTime} and #{endTime}
</select>


相关文章
|
6天前
|
JSON API 数据格式
OpenCode入门使用教程
本教程介绍如何通过安装OpenCode并配置Canopy Wave API来使用开源模型。首先全局安装OpenCode,然后设置API密钥并创建配置文件,最后在控制台中连接模型并开始交互。
2481 6
|
12天前
|
人工智能 JavaScript Linux
【Claude Code 全攻略】终端AI编程助手从入门到进阶(2026最新版)
Claude Code是Anthropic推出的终端原生AI编程助手,支持40+语言、200k超长上下文,无需切换IDE即可实现代码生成、调试、项目导航与自动化任务。本文详解其安装配置、四大核心功能及进阶技巧,助你全面提升开发效率,搭配GitHub Copilot使用更佳。
|
14天前
|
存储 人工智能 自然语言处理
OpenSpec技术规范+实例应用
OpenSpec 是面向 AI 智能体的轻量级规范驱动开发框架,通过“提案-审查-实施-归档”工作流,解决 AI 编程中的需求偏移与不可预测性问题。它以机器可读的规范为“单一真相源”,将模糊提示转化为可落地的工程实践,助力开发者高效构建稳定、可审计的生产级系统,实现从“凭感觉聊天”到“按规范开发”的跃迁。
2043 18
|
2天前
|
人工智能 API 开发者
Claude Code 国内保姆级使用指南:实测 GLM-4.7 与 Claude Opus 4.5 全方案解
Claude Code是Anthropic推出的编程AI代理工具。2026年国内开发者可通过配置`ANTHROPIC_BASE_URL`实现本地化接入:①极速平替——用Qwen Code v0.5.0或GLM-4.7,毫秒响应,适合日常编码;②满血原版——经灵芽API中转调用Claude Opus 4.5,胜任复杂架构与深度推理。
|
6天前
|
人工智能 前端开发 Docker
Huobao Drama 开源短剧生成平台:从剧本到视频
Huobao Drama 是一个基于 Go + Vue3 的开源 AI 短剧自动化生成平台,支持剧本解析、角色与分镜生成、图生视频及剪辑合成,覆盖短剧生产全链路。内置角色管理、分镜设计、视频合成、任务追踪等功能,支持本地部署与多模型接入(如 OpenAI、Ollama、火山等),搭配 FFmpeg 实现高效视频处理,适用于短剧工作流验证与自建 AI 创作后台。
951 4
|
12天前
|
人工智能 JavaScript 前端开发
【2026最新最全】一篇文章带你学会Cursor编程工具
本文介绍了Cursor的下载安装、账号注册、汉化设置、核心模式(Agent、Plan、Debug、Ask)及高阶功能,如@引用、@Doc文档库、@Browser自动化和Rules规则配置,助力开发者高效使用AI编程工具。
1513 7
|
5天前
|
人工智能 运维 前端开发
Claude Code 30k+ star官方插件,小白也能写专业级代码
Superpowers是Claude Code官方插件,由核心开发者Jesse打造,上线3个月获3万star。它集成brainstorming、TDD、系统化调试等专业开发流程,让AI写代码更规范高效。开源免费,安装简单,实测显著提升开发质量与效率,值得开发者尝试。
|
16天前
|
人工智能 测试技术 开发者
AI Coding后端开发实战:解锁AI辅助编程新范式
本文系统阐述了AI时代开发者如何高效协作AI Coding工具,强调破除认知误区、构建个人上下文管理体系,并精准判断AI输出质量。通过实战流程与案例,助力开发者实现从编码到架构思维的跃迁,成为人机协同的“超级开发者”。
1172 99
|
12天前
|
人工智能 JSON 自然语言处理
【2026最新最全】一篇文章带你学会Qoder编辑器
Qoder是一款面向程序员的AI编程助手,集智能补全、对话式编程、项目级理解、任务模式与规则驱动于一体,支持模型分级选择与CLI命令行操作,可自动生成文档、优化提示词,提升开发效率。
913 10
【2026最新最全】一篇文章带你学会Qoder编辑器

热门文章

最新文章