十三、市场活动:全部导出

news/2024/4/28 2:09:32/文章来源:https://blog.csdn.net/jbkjhji/article/details/130125972

功能需求:批量导出市场活动

用户在市场活动主页面,点击"批量导出"按钮,把所有市场活动生成一个excel文件,弹出文件下载的对话框;

 用户选择要保存的目录,完成导出市场活动的功能.

*导出成功之后,页面不刷新

功能分析:导出市场活动

1.给批量“导出”按钮,单击事件。点击按钮,向后台发送导出请求

2.后台controller接收请求,查询所有的市场活动

3.创建一个excel文件,把查询出来的文件写道excel文件中

4.把生成的excel文件,输出到浏览器,进行下载

文件导出插件:apache-poi插件

【技术准备】

把办公文档的所有元素封装成普通java类,通过操作这些类进行文件导出

  • HSSFRow------行
  • HSSFCell-------列
  • HSSFSheet-------页
  • HSSFWorkbook-------文件
  • HSSFCellStyle--------样式

【插件使用】

1.添加依赖

        <dependency><groupId>org.apache.poi</groupId><artifactId>poi</artifactId><version>3.15</version></dependency>

2.使用封装类生成excel

3.文件下载

全部导出流程图

 代码实现

一、ActivityMapper

1.ActivityMapper接口

    /*** 批量导出*/List<Activity> selectAllActivities();
    <select id="selectAllActivities" resultMap="BaseResultMap">select a.id,u1.name as owner,a.name,a.start_date,a.end_date,a.cost,a.description,a.create_time,u2.name as create_by,a.edit_time,u3.name as edit_byfrom tbl_activity ajoin tbl_user u1 on a.owner = u1.idjoin tbl_user u2 on a.create_by = u2.idleft join tbl_user u3 on a.edit_by = u3.idorder by a.create_time desc</select>

二、ActivityService

	/*** 批量导出*/List<Activity> queryAllActivities();
	@Overridepublic List<Activity> queryAllActivities() {return activityMapper.selectAllActivities();}

三、ActivityController

1.写一个下载文件的工具类HSSFUtils

/*** 下载市场活动的Excel* activityList 市场活动集合* fileName文件名*/public static void createExcelByActivityList(List<Activity> activityList, String fileName, HttpServletResponse response) throws Exception {// 2.创建Excel// 2.1.1创建文件HSSFWorkbook wb = new HSSFWorkbook();// 2.1.2 创建表HSSFSheet sheet = wb.createSheet("市场活动");// 2.1.3 创建行和列HSSFRow row = sheet.createRow(0);HSSFCell cell = row.createCell(0);// 2.1.4 列的设置cell.setCellValue("ID");cell = row.createCell(1);cell.setCellValue("所有者");cell = row.createCell(2);cell.setCellValue("名称");cell = row.createCell(3);cell.setCellValue("开始日期");cell = row.createCell(4);cell.setCellValue("结束日期");cell = row.createCell(5);cell.setCellValue("成本");cell = row.createCell(6);cell.setCellValue("描述");cell = row.createCell(7);cell.setCellValue("创建时间");cell = row.createCell(8);cell.setCellValue("创建者");cell = row.createCell(9);cell.setCellValue("修改日期");cell = row.createCell(10);cell.setCellValue("修改者");if (activityList != null && activityList.size() > 0) {Activity activity = null;for (int i = 0; i < activityList.size(); i++) {activity = activityList.get(i);//生成行row = sheet.createRow(i + 1);//创建列cell = row.createCell(0);cell.setCellValue(activity.getId());cell = row.createCell(1);cell.setCellValue(activity.getOwner());cell = row.createCell(2);cell.setCellValue(activity.getName());cell = row.createCell(3);cell.setCellValue(activity.getStartDate());cell = row.createCell(4);cell.setCellValue(activity.getEndDate());cell = row.createCell(5);cell.setCellValue(activity.getCost());cell = row.createCell(6);cell.setCellValue(activity.getDescription());cell = row.createCell(7);cell.setCellValue(activity.getCreateTime());cell = row.createCell(8);cell.setCellValue(activity.getCreateBy());cell = row.createCell(9);cell.setCellValue(activity.getEditTime());cell = row.createCell(10);cell.setCellValue(activity.getEditBy());}}// 3 调用工具函数生成Excel文件。// 4 文件下载// 4.1 设置响应类型  excel文件是application/octet-stream二进制文件response.setContentType("application/octet-stream;charset=UTF-8");// 激活文件下载窗口 Content-Disposition不打开,attachment附件response.addHeader("Content-Disposition", "attachment;filename=" + fileName);// 4.2 获取输出流ServletOutputStream out = response.getOutputStream();wb.write(out);// 3.2 关闭资源wb.close();out.flush(); // 输出流缓存中的内容强制输出,但并不会关闭输出流}

 

	/*** 批量导出*/@RequestMapping("/workbench/activity/exportAllActivities.do")public void exportAllActivities(HttpServletResponse response) throws Exception {// 1 调用service方法,查询所有的市场活动List<Activity> activityList = activityService.queryAllActivities();// 2.文件下载HSSFUtils.createExcelByActivityList(activityList,Contants.FILE_NAME_ACTIVITY,response);}

 四、前端index.jsp

给批量的按钮添加单击事件,跳转到controller层

            // 下载:全选$("#exportActivityAllBtn").click(function () {window.location.href = "workbench/activity/exportAllActivities.do";});

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

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

相关文章

Vue组件化编程【Vue】

2.Vue 组件化编程 2.1 模块与组件、模块化与组件化 2.1.1 模块 理解&#xff1a;向外提供特定功能的js程序&#xff0c;一般就是一个js文件为什么&#xff1a;js文件很多很复杂作用&#xff1a;复用js、简化js的编写、提高js运行效率。 2.1.2 组件 理解&#xff1a;用来实…

接口自动化【一】(抓取后台登录接口+postman请求通过+requests请求通过+json字典区别)

文章目录 前言一、requests库的使用二、json和字典的区别三、后端登录接口-请求数据生成四、接口自动化-对应电商项目中的功能五、来自postman的代码-后端登录总结前言 记录&#xff1a;json和字典的区别&#xff0c;json和字段的相互转化&#xff1b;postman发送请求与Python…

source insight4.0使用技巧总结

一、技巧1&#xff1a;查看函数调用关系 步骤 1&#xff1a;在主菜单中点击下图中的按钮 图 1 打开relation界面 步骤 2&#xff1a;在弹出的relation界面点击“设置”按钮&#xff0c; 图2 点击“设置”按钮 步骤3&#xff1a; 在“设置”界面中&#xff0c;“Levels”选择…

AC7811-FOC无感控制代码详解

目录 矢量控制原理 矢量控制框图 电流采样方式 电流在整个控制过程中的传递 采样关键点 三电阻 双电阻 单电阻 三者对比 坐标变换 dq轴电流的PI控制 启动方式 启动波形 脉冲注入 高频注入 Startup 预定位到指定角度 PulseInject_api hfi_api Speed loop s…

前端学习:HTML块、类、Id

目录 快 一、块元素、内联元素 二、HTML 元素 三、HTML元素 类 一、分类块级元素 二、分类行内元素 Id 一、使用 id 属性 二、 class与ID的差异 三、总结 快 一、块元素、内联元素 大多数HTML元素被定义为块级元素或内联元素。 块级元素在浏览器显示时&#xff0c;通常会…

FTP-----局域网内部传输文件(1)

在日常工作中&#xff0c;如果需要跨设备的传输文件&#xff0c;您需要借助USB数据线或者借助应用实现无线互联&#xff0c;将所需文件传输到对应设备&#xff0c;这一来一去&#xff0c;花费的时间与精力变多了&#xff0c;那么&#xff0c;怎么实现不使用第三方软件来实现跨设…

3-5年以上的功能测试如何进阶自动化?【附学习路线】

做为功能测试人员来讲&#xff0c;从发展方向上可分两个方面&#xff1a; 1、业务流程方向 2、专业技能方向。 当确定好方向后&#xff0c;接下来就是如何达到了。(文末自动化测试学习资料分享) 一、业务流程方向 1、熟悉底层的业务 作为功能测试工程师来讲&#xff0c;了解…

【C++高级】手写线程池项目-经典死锁问题分析-简历项目输出指导

作为五大池之一&#xff0c; 线程池的应用非常广 泛&#xff0c;不管是客户端程序&#xff0c;还是后台服务程序&#xff0c;掌握线程池&#xff0c;是提高业务处理能力的必备模块 本课程将带你从零开始&#xff0c;设计一个支持fixed和cached模式的线程池&#xff0c;玩转C11、…

IGA_PLSM3D的理解1

文章目录前言一、IgaTop3D_FAST.m给的参数二、Material properties 材料特性对Geom_Mod3D的理解对Pre_IGA3D的理解 输出1-----CtrPts&#xff1a; 输出2-----Ele&#xff1a; 输出3-----GauPts&#xff1a;前言 只是为方便学习&#xff0c;不做其他用途 一、IgaTop3D_FAST.m给的…

Python爬虫-某跨境电商(AM)搜索热词

前言 本文是该专栏的第42篇,后面会持续分享python爬虫干货知识,记得关注。 关于某跨境电商(AM),本专栏前面有单独详细介绍过,获取配送地的cookie信息以及商品库存数据,感兴趣的同学可往前翻阅。 1. python爬虫|爬取某跨境电商AM的商品库存数据(Selenium实战) 2. Seleni…

5.39 综合案例2.0 - STM32蓝牙遥控小车1(手机APP遥控)

综合案例2.0 - 蓝牙遥控小车1- 手机APP遥控成品展示案例说明器件说明连线小车源码手机遥控APPAPP使用说明成品展示 案例说明 用STM32单片机做了一辆蓝牙控制的麦轮小车&#xff0c;分享一下小车的原理和制作过程。 控制部分分为手机APP&#xff0c;语音模块控制&#xff0c;Ha…

15-721 chapter2 内存数据库

Background 随着时代的发展&#xff0c;DRAM可以容纳足够的便宜&#xff0c;容量也变大了。对于数据库来说&#xff0c;数据完全可以fit in memory&#xff0c;但同时面向disk的数据库架构不能很好的发挥这个特性 这张图是disk database的cpu instruction cost 想buffer pool…

第5章 继承-Java核心技术·卷1

文章目录Java与C不同基本概念继承&#xff1a;基于已有的类创建新的类。构造器多态定义超类变量可以引用所有的子类对象&#xff0c;但子类变量不能引用超类对象。子类引用的数组可以转换成超类引用的数组覆写返回子类型强制类型转换阻止继承&#xff1a;final类和方法多态 vs …

ROS学习-ROS简介

文章目录1.ROS1.1 ROS概念1.2 ROS特征1.3 ROS特点1.4 ROS版本1.5 ROS程序其他名词介绍1. 元操作系统2. IDL 接口定义语言一些网站1.ROS 1.1 ROS概念 ROS(Robot Operating System&#xff0c;机器人操作系统) ROS 是一个适用于机器人的开源的元操作系统&#xff0c;提供一系列…

linux驱动开发 - 04_Linux 设备树学习 - DTS语法

文章目录Linux 设备树学习 - DTS语法1 什么是设备树&#xff1f;2 DTS、DTB和DTC3 DTS 语法3.1 dtsi 头文件3.2 设备节点3.3 标准属性1、compatible 属性2、model 属性3、status 属性4、#address-cells 和#size-cells 属性5、reg 属性6、ranges 属性7、name 属性8、device_type…

人工智能专题-知识表示

文章目录人工智能专题-知识表示大纲2.1 知识表示的概念2.1.1 知识表示观点2.1.2 知识表示的要求2.2 一阶谓词逻辑表示法2.2.1 一阶谓词概念2.2.2 谓词逻辑表示方法2.3 产生式表示法2.4 语义网络表示法2.5 框架表示法人工智能专题-知识表示 大纲 大纲&#xff1a;掌握知识表示方…

思科路由器发现重大漏洞,解决方法是……

晚上好&#xff0c;我是老杨。 思科知名度高&#xff0c;待遇也好&#xff0c;很多网工心生向往&#xff0c;也有很多人考过思科认证的相关证书&#xff0c;对思科的印象还是不错吧&#xff1f; 而且&#xff0c;作为美国著名的网络设备厂商&#xff0c;思科是全球路由器巨头…

【面试】如何设计SaaS产品的数据权限?

文章目录前言数据权限是什么&#xff1f;设计原则整体方案RBAC模型怎么控制数据权限&#xff1f;1. 数据范围权限控制2. 业务对象操作权限控制3. 业务对象字段权限控制总结前言 一套系统的权限可以分为两类&#xff0c;数据权限和功能权限&#xff0c;今天我们从以下几个点&am…

【RabbitMQ】初识消息中间件MQ

目录 一、什么是MQ 二、MQ的优缺点 1、MQ的优点 1.应用解耦 2.削峰填谷 3.异步提速 2、MQ的缺点 1.可用性低 2.系统复杂度高 3.数据一致性问题 三、MQ使用场景 四、常见的MQ 一、什么是MQ MQ&#xff08;Message Queue&#xff09;&#xff1a;消息队列&#xff0c…

代码随想录_二叉树_leetcode654 617

leetcode654 最大二叉树 654. 最大二叉树 给定一个不重复的整数数组 nums 。 最大二叉树 可以用下面的算法从 nums 递归地构建: 创建一个根节点&#xff0c;其值为 nums 中的最大值。递归地在最大值 左边 的 子数组前缀上 构建左子树。递归地在最大值 右边 的 子数组后缀上 …