项目-苍穹外卖(十七) Apache POI+导出数据

一、介绍

二、入门案例

package com.sky.test;import org.apache.poi.xssf.usermodel.XSSFRow;
import org.apache.poi.xssf.usermodel.XSSFSheet;
import org.apache.poi.xssf.usermodel.XSSFWorkbook;import java.io.File;
import java.io.FileNotFoundException;
import java.io.FileOutputStream;
import java.io.IOException;/*
* 使用POI操作Excel文件
* */
public class POITest {public static void write() throws IOException {//在内存中创建一个excel文件XSSFWorkbook excel= new XSSFWorkbook();//在excel文件中创建一个sheet页XSSFSheet sheet=excel.createSheet("info");//在Sheet中创建行对象,rownum编号从0开始XSSFRow row=sheet.createRow(1);//在行上创建单元格 索引从0开始 并设置单元格内容row.createCell(1).setCellValue("姓名哈哈哈");row.createCell(2).setCellValue("城市哈哈哈");//创建一个新行 第三行row=sheet.createRow(2);row.createCell(1).setCellValue("张三");row.createCell(2).setCellValue("伤害");//创建一个新行 第四行row=sheet.createRow(3);row.createCell(1).setCellValue("李四");row.createCell(2).setCellValue("南京");//通过输出流 将内存中的excel文件写入到磁盘FileOutputStream out = new FileOutputStream(new File("D:\\1、黑马程序员Java项目《苍穹外卖》企业级开发实战\\资料\\资料\\day12\\info.xlsx"));excel.write(out);out.close();excel.close();}public static void main(String[] args) throws IOException {write();}
}

 public static void read() throws IOException {//创建输入流FileInputStream fileInputStream = new FileInputStream(new File("D:\\1、黑马程序员Java项目《苍穹外卖》企业级开发实战\\资料\\资料\\day12\\info.xlsx"));//读取磁盘上已经存在的excel文件XSSFWorkbook excel = new XSSFWorkbook(fileInputStream);//读取Excel文件中的第一个sheet页 索引从0开始XSSFSheet sheet = excel.getSheetAt(0);//获取sheet中最后一行的行号int lastRowNum = sheet.getLastRowNum();for(int i=1;i<=lastRowNum;i++){//获得某一行XSSFRow row = sheet.getRow(i);//获得单元格对象中的文本内容String stringCellValue = row.getCell(1).getStringCellValue();String stringCellValue1 = row.getCell(2).getStringCellValue();System.out.println(stringCellValue +" "+stringCellValue1);}excel.close();fileInputStream.close();}public static void main(String[] args) throws IOException {read();}

三、导出数据

需求分析和设计:

Controller:

    /*** 导出数据* */@GetMapping("/export")@ApiOperation("导出运营数据Excel报表")public void export(HttpServletResponse response) throws IOException {log.info("导出数据..");reportService.exportBussinessData(response);}

Servcie:

    /*** 导出运营数据报表* */void exportBussinessData(HttpServletResponse response) throws IOException;
    /*** 导出运营数据报表* */@Overridepublic void exportBussinessData(HttpServletResponse response) throws IOException {//查询数据库,获取营业数据LocalDate dateBegin = LocalDate.now().minusDays(30);LocalDate dateEnd = LocalDate.now().minusDays(1);BusinessDataVO businessData = workspaceService.getBusinessData(LocalDateTime.of(dateBegin, LocalTime.MIN),LocalDateTime.of(dateEnd, LocalTime.MAX));//将数据写入到excel文件 POI写入InputStream input = this.getClass().getClassLoader().getResourceAsStream("template/运营数据报表模板.xlsx");//基于一个模板文件创建一个新的Excel文件try {XSSFWorkbook excel=new XSSFWorkbook(input);//填充数据//按名字获取sheet页XSSFSheet sheet = excel.getSheet("Sheet1");//填充时间--获得第二行sheet.getRow(1).getCell(1).setCellValue("时间: "+dateBegin+"至"+dateEnd);sheet.getRow(3).getCell(2).setCellValue(businessData.getTurnover());sheet.getRow(3).getCell(4).setCellValue(businessData.getOrderCompletionRate());sheet.getRow(3).getCell(6).setCellValue(businessData.getNewUsers());sheet.getRow(4).getCell(2).setCellValue(businessData.getValidOrderCount());sheet.getRow(4).getCell(4).setCellValue(businessData.getUnitPrice());//明细数据for(int i=0;i<30;i++){LocalDate localDate = dateBegin.plusDays(i);BusinessDataVO businessData1 = workspaceService.getBusinessData(LocalDateTime.of(dateBegin, LocalTime.MIN),LocalDateTime.of(dateBegin, LocalTime.MAX));sheet.getRow(7+i).getCell(1).setCellValue(localDate.toString());sheet.getRow(7+i).getCell(2).setCellValue(businessData1.getTurnover());sheet.getRow(7+i).getCell(3).setCellValue(businessData1.getValidOrderCount());sheet.getRow(7+i).getCell(4).setCellValue(businessData1.getOrderCompletionRate());sheet.getRow(7+i).getCell(5).setCellValue(businessData1.getUnitPrice());sheet.getRow(7+i).getCell(6).setCellValue(businessData1.getNewUsers());}//通过输出流将excel文件导出到浏览器ServletOutputStream outputStream = response.getOutputStream();excel.write(outputStream);//关闭资源outputStream.close();excel.close();} catch (IOException e) {e.printStackTrace();}}

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

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

相关文章

2023第十四届蓝桥杯大赛软件赛国赛C/C++ 大学 B 组(真题题解)(C++/Java题解)

本来想刷省赛题呢&#xff0c;结果一不小心刷成国赛了 真是个小迷糊〒▽〒 但&#xff0c;又如何( •̀ ω •́ )✧ 记录刷题的过程、感悟、题解。 希望能帮到&#xff0c;那些与我一同前行的&#xff0c;来自远方的朋友&#x1f609; 大纲&#xff1a; 一、子2023-&#xff…

Cannot find a valid baseurl for repo: centos-sclo-sclo/x86_64

​ rpm -Uvh https://repo.zabbix.com/zabbix/5.0/rhel/7/x86_64/zabbix-release-latest-5.0.el7.noarch.rpmyum clean allyum macache fast​ 编辑配置文件 /etc/yum.repos.d/zabbix.repo and enable zabbix-frontend repository. [zabbix-frontend]...enabled1... 下载相关…

【STM32】WDG看门狗(学习笔记)

学习来源----->江协科技STM32 WDG简介 WDG&#xff08;Watchdog&#xff09;看门狗看门狗可以监控程序的运行状态&#xff0c;当程序因为设计漏洞、硬件故障、电磁干扰等原因&#xff0c;出现卡死或跑飞现象时&#xff0c;看门狗能及时复位程序&#xff0c;避免程序陷入长…

Nginx RTMP 服务器开发设计与实现

引言 Nginx 是一个高性能的 Web 服务器和反向代理服务器&#xff0c;广泛应用于大规模网站的高并发访问中。RTMP&#xff08;Real-Time Messaging Protocol&#xff09;是由 Adobe 提出的一个用于流媒体传输的协议&#xff0c;广泛应用于视频直播领域。通过 Nginx 的 RTMP 模块…

plantsimulation编辑图标怎么把图标旋转90°

1、打开要旋转的图标&#xff0c;点击“导出” 2、随意设置个文件名&#xff0c;点击保存。 3、用画图打开&#xff0c;点击旋转后保存。 4、新建一个图标&#xff0c;点击导入&#xff0c;选择刚刚保存的文件即可。

Jmeter性能测试

Jmeter性能测试 一、性能测试介绍 1、什么叫做性能测试&#xff1f; &#xff08;1&#xff09;通过某些工具或手段来检测软件的某些指标是否达到了要求&#xff0c;这就是性能测试 &#xff08;2&#xff09;指通过自动化的测试工具模拟多种正常、峰值以及异常负载条件来对系…

OpenCV基础——梯度计算、边缘检测、图像金字塔

接上期&#xff1a; OpenCV基础——图像滤波和形态学操作-CSDN博客 一.梯度计算 上贴已经讲过&#xff0c;梯度可以浅显地理解为图像中发生颜色变化的局部区域&#xff0c;也即边界点。本质上是通过构造与卷积核相同的矩阵&#xff0c;计算边缘区域像素点的差异值——也即梯度…

英语学习笔记1

目录 第一部分 例句解析 句子一 原文&#xff1a;Learning English is never easy but always rewarding!翻译&#xff1a;学习英语从来都不容易但总是有回报的&#xff01; 句子二 原文&#xff1a;Sometimes the detailed work of understanding grammar and building v…

测试测试 测试

**非常详细的视频和文字教程&#xff0c;讲解常见的openmv教程包括 巡线、物体识别、圆环识别、阈值自动获取等。非常适合学习openmv、K210、K230等项目 视频合集链接在 openmv教程合集 openmv入门到项目开发 openmv和STM32通信 openmv和opencv区别 openmv巡线 openmv数字识别教…

CSS rem、vw/vh、less

目录 分辨率、视口与二倍图 一、分辨率与像素基础 1. 物理像素&#xff08;Physical Pixels&#xff09; 2. 逻辑像素&#xff08;CSS 像素&#xff09; 二、视口&#xff08;Viewport&#xff09;控制 1. 视口类型 2. 设置理想视口 三、二倍图&#xff08;Retina/HiD…

【数电】半导体存储电路

组合逻辑电路输入和输出之间是确定关系&#xff0c;与之前的历史记录没有任何关系。时序逻辑电路则有相应的存储元件&#xff0c;要把之前的状态保存起来。 要构成时序逻辑电路&#xff0c;必须要有相应的存储元件&#xff0c;第五章讲述相应的存储元件 一、半导体存储电路概…

OPPO手机如何实时翻译会议视频?视频翻译轻松应对多语言场景

在全球化日益深入的今天&#xff0c;跨语言沟通已成为职场和生活中的常见需求。无论是参加国际会议、观看外语视频&#xff0c;还是与海外客户交流&#xff0c;语言障碍都可能成为效率的绊脚石。幸运的是&#xff0c;OPPO手机凭借其强大的功能和智能化设计&#xff0c;为用户提…

28_跨域

目录 promise promise的基本语法 async await try catch promise 静态方法 跨域 跨域的解决方案 1-cors ​编辑 2-jsonp方案 3-代理服务器 promise promise 是一个es6新增的语法 承诺的意思 作用:是专门用来解决回调地狱!!!! promise的基本语法 // 基本语法:// Pr…

LeetCode Hot100 刷题笔记(4)—— 二叉树、图论

目录 一、二叉树 1. 二叉树的深度遍历&#xff08;DFS&#xff1a;前序、中序、后序遍历&#xff09; 2. 二叉树的最大深度 3. 翻转二叉树 4. 对称二叉树 5. 二叉树的直径 6. 二叉树的层序遍历 7. 将有序数组转换为二叉搜索树 8. 验证二叉搜索树 9. 二叉搜索树中第 K 小的元素 …

【漏洞复现】Apache Tomcat partial PUT文件上传反序列化漏洞复现(CVE-2025-24813)

❤️博客主页&#xff1a; iknow181 &#x1f525;系列专栏&#xff1a; 网络安全、 Python、JavaSE、JavaWeb、CCNP &#x1f389;欢迎大家点赞&#x1f44d;收藏⭐评论✍ 0x00 免责声明 本文所述漏洞复现方法仅供安全研究及授权测试使用&#xff1b;任何个人/组织须在合法合规…

BurpSuit抓包失败-基础配置

问题描述&#xff1a;当开启拦截抓包的时候&#xff0c;burpsuite没有反应&#xff0c;好不容易经过一通配置&#xff0c;浏览器出现无法访问的情况。 解决办法&#xff1a; 下载浏览器插件 首先下载一个代理转换插件&#xff1a;Omega&#xff0c;这样比较方便&#xff0c;…

求解AX=XB 方法

一、简介 一文浅谈旋转变换&#xff1a;旋转矩阵、旋转向量、欧拉角、四元数-CSDN博客 在机器人学、计算机视觉和几何学中&#xff0c;经常会遇到求解矩阵方程 AXXB 的问题。这种方程通常出现在坐标系变换、手眼标定&#xff08;Hand-Eye Calibration&#xff09;等场景中。理…

AnimateCC基础教学:随机抽取获奖名单及奖品-V1.0原型版

舞台界面设计: 主轴第一帧代码&#xff1a; this.btnObj.addEventListener("click", updateStage.bind(this)); createjs.Ticker.addEventListener("tick", updateRandom.bind(this)) var _this this; var bPlaying false; var nameList ["张三…

深入了解Linux内核:task_struct结构详解

Linux 操作系统的广袤世界里&#xff0c;进程管理宛如一座大厦的基石&#xff0c;支撑着整个系统的稳定运行与高效运转 。而task_struct结构体&#xff0c;无疑是进程管理这座大厦的核心支柱&#xff0c;它承载着进程的关键信息&#xff0c;贯穿于进程从诞生到消亡的整个生命周…

IsaacLab最新2025教程(7)-引入IK solver控制机器人

机器人控制可以直接给定关节角进行驱动实现功能&#xff0c;完成任务&#xff0c;但是关节角不是很直观而且做teleoperation或者是结合VLA模型时候&#xff0c;用eef pose会更符合直觉一些&#xff0c;isaacsim用的是LulaKinematics&#xff0c;因为IsaacLab现在是ETHZ的团队在…