java生成日历数据列表并按日历格式导出到excel

日历格式输出

  • 日历数据列表
    • 导出封装日历格式
    • 实体类
    • 效果

日历数据列表

/**** 封装日历数据* @param year 年份* @param month 月份*/public List<InspectionDailyStaffPlanCalendarData> selectCalendarDataList(int year,int month,List<InspectionDailyStaffPlan> staffPlansList) {//根据日期创建对象,默认当月第一天LocalDate of = LocalDate.of(year, month, 1);//获取当月第一天是周几int valueOfWeek = of.getDayOfWeek().getValue();//判断是否闰年(闰年2月有29天)boolean leapYear = of.isLeapYear();//获取输入月份共有多少天int monthDay = of.getMonth().length(leapYear);List<InspectionDailyStaffPlanCalendarData> list = new ArrayList<>();int weekNum = valueOfWeek;LocalDate today = LocalDate.now(); // 获取今天的日期//打印每个月的日期数for (int i = 1; i <= monthDay; i++) {InspectionDailyStaffPlanCalendarData calendarData = new InspectionDailyStaffPlanCalendarData();calendarData.setDay(i);calendarData.setYear(year);calendarData.setMonth(month);String dateStr = year+"-"+month+"-"+(i<10?"0"+i:i);calendarData.setPlanDate(DateUtils.getDate(dateStr));LocalDate otherDate = LocalDate.of(year, month, i);//判断是否是今日if (today.equals(otherDate)) {calendarData.setToday(1);} else {calendarData.setToday(0);}calendarData.setWeek(WeekEnums.getName(weekNum));if ((i+valueOfWeek-1) % 7 == 0){System.out.println();weekNum = 1;}else{weekNum = weekNum+1;}if(CollUtil.isNotEmpty(staffPlansList)){//封装值班领导和值班人员for (InspectionDailyStaffPlan staffPlan:staffPlansList) {if(staffPlan.getPlanDate().equals(calendarData.getPlanDate())){calendarData.setId(staffPlan.getId());calendarData.setStaffLeaderName(staffPlan.getStaffUserLNames());calendarData.setStaffUserNames(staffPlan.getStaffUserMNames());}}}list.add(calendarData);}return list;}

导出封装日历格式

@Override@SneakyThrowspublic void exportCalendarData(InspectionDailyStaffPlan query) {Date planDate = query.getPlanDate();List<InspectionDailyStaffPlanCalendarData> list = selectCalendarDataList(query);if(CollUtil.isEmpty(list)){throw new BusinessException("导出数据为空.");}ServletRequestAttributes requestAttributes = (ServletRequestAttributes) RequestContextHolder.getRequestAttributes();HttpServletResponse response = requestAttributes.getResponse();response.setContentType("application/vnd.ms-excel");response.setCharacterEncoding("utf-8");// 这里URLEncoder.encode可以防止中文乱码 当然和easyexcel没有关系String fileName = URLEncoder.encode("每月排班记录" + DateUtil.today(), StandardCharsets.UTF_8.toString());response.setHeader("Content-disposition", "attachment;filename=" + fileName + ".xlsx");EasyExcel.write(response.getOutputStream()).head(StaffPlanCalendarExcelData.head()).sheet().doWrite(StaffPlanCalendarExcelData.getCalendarData(planDate,list));}/**** 导出表头封装* @param* @return*/public static List<List<String>> head() {List<List<String>> headTitles = ListUtils.newArrayList();headTitles.add(ListUtils.newArrayList("星期一"));headTitles.add(ListUtils.newArrayList("星期二"));headTitles.add(ListUtils.newArrayList("星期三"));headTitles.add(ListUtils.newArrayList("星期四"));headTitles.add(ListUtils.newArrayList("星期五"));headTitles.add(ListUtils.newArrayList("星期六"));headTitles.add(ListUtils.newArrayList("星期日"));return headTitles;}/**** 封装日历数据* dataList 封装好的日历列表*/public static List<List<Object>> getCalendarData(Date planDate, List<InspectionDailyStaffPlanCalendarData> dataList) {LocalDate localDate = planDate.toInstant().atZone(ZoneId.systemDefault()).toLocalDate();int year = localDate.getYear();int month = localDate.getMonthValue();List<List<Object>> contentList = ListUtils.newArrayList();if (CollUtil.isEmpty(dataList)) {return contentList;}//根据日期创建对象,默认当月第一天LocalDate of = LocalDate.of(year, month, 1);//获取当月第一天是周几int valueOfWeek = of.getDayOfWeek().getValue();List<Object> data = new ArrayList<>();for (int i = 1; i < valueOfWeek; i++) {data.add("");}//判断是否闰年(闰年2月有29天)boolean leapYear = of.isLeapYear();//获取输入月份共有多少天int monthDay = of.getMonth().length(leapYear);//打印每个月的日期数int weekNum = 1;for (int i = 1; i <= monthDay; i++) {if ((i+valueOfWeek-1) % 7 == 0){weekNum++;}}//周int dayOfWeek = 7-valueOfWeek;int val = 0;for (int y = 1; y <= weekNum; y++) {List<Object> obj = new ArrayList<>();for (int i = 1; i <=7; i++) {String str = "";if(dataList.size()>0){InspectionDailyStaffPlanCalendarData calendarData = dataList.get(0);str = "\t\t"+ calendarData.getDay()+"\n";String lNames = StringUtils.isNoneBlank(calendarData.getStaffLeaderName())?"值班领导:"+calendarData.getStaffLeaderName()+"\n":"";String mNames = StringUtils.isNoneBlank(calendarData.getStaffUserNames())?"值班人员:"+calendarData.getStaffUserNames():"";str = "\t\t"+ calendarData.getDay()+"\n"+lNames+mNames;dataList.remove(calendarData);}if(dayOfWeek>=0){dayOfWeek--;data.add(str);}else{obj.add(str);}val++;if ((val+valueOfWeek-1) % 7 == 0){break;}}if(y == 1){contentList.add(data);}else{contentList.add(obj);}}return contentList;}

实体类

public class InspectionDailyStaffPlanCalendarData
{private static final long serialVersionUID = 1L;/** 主键id */private Long id;private int year;private int month;private int day;/** 值班计划日期 */@JsonFormat(pattern = "yyyy-MM-dd")private Date planDate;/** 星期 */private String week;/** 值班领导 */private String staffLeaderName;/** 值班人员 */private String staffUserNames;/** 是否今日 1:是 */private int today;}

效果

日历列表图:
在这里插入图片描述
导出数据:
在这里插入图片描述

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

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

相关文章

面试(十)

目录 一. 单元测试 二. FreeRTOS和裸机哪个实时性好&#xff1f; 三. 怎么判断某个程序的运行时间 四. 函数指针 五. 全局变量被线程使用冲突 5.1 使用互斥锁 5.2 使用读写锁 5.3 使用原子操作 六. 局部变量没有初始化是什么值 七. uint_8 n 255 , n等于多少 八. …

Unity UndoRedo(撤销重做)功能

需求 撤销与重做功能 思考 关于记录的数据的两点思考&#xff1a; 记录操作记录影响显示和逻辑的所有数据 很显然这里就要考虑取舍了&#xff1a; 记录操作 这种方案只需要记录每一步的操作&#xff0c;具体这个操作要怎么渲染和实现出来完全需要自己去实现&#xff0c;这…

JAVA-数据结构-排序

1.直接插入排序 1.原理&#xff1a;和玩扑克牌一样&#xff0c;从左边第二个牌开始&#xff0c;选中这个&#xff0c;和前面的所有牌比较&#xff0c;插在合适的位置 public static void insertsort(int[] arr){//直接插入排序for (int i 1; i < arr.length; i) {//此循环…

手撕数据结构 —— 栈(C语言讲解)

目录 1.认识栈 什么是栈 栈的示意图 2.如何实现栈 3.栈的实现 Stack.h中接口总览 具体实现 结构的定义 初始化栈 销毁栈 入栈 出栈 取栈顶元素 获取有效元素的个数 判断栈是否为空 4.完整代码附录 Stack.h Stack.c 1.认识栈 什么是栈 栈是一种特殊的线性表…

学视频剪辑需要电脑吗 学视频剪辑需要什么条件

态度决定成败&#xff0c;学剪辑亦是如此。我们都在学习剪辑的道路上寻找答案&#xff0c;电脑就像指引答案的工具&#xff0c;但它本身并不是答案。所以&#xff0c;好电脑不等于好剪辑师。想要学好视频剪辑&#xff0c;你只需要一个态度端正的自己。有关学视频剪辑需要电脑吗…

Spring Cloud Stream 3.x+kafka 3.8整合

Spring Cloud Stream 3.xkafka 3.8整合&#xff0c;文末有完整项目链接 前言一、如何看官方文档(有深入了解需求的人)二、kafka的安装tar包安装docker安装 三、代码中集成创建一个测试topic&#xff1a;testproducer代码producer配置&#xff08;配置的格式&#xff0c;上篇文章…

基于SpringBoot+Vue的疫苗预约接种管理系统

作者&#xff1a;计算机学姐 开发技术&#xff1a;SpringBoot、SSM、Vue、MySQL、JSP、ElementUI、Python、小程序等&#xff0c;“文末源码”。 专栏推荐&#xff1a;前后端分离项目源码、SpringBoot项目源码、Vue项目源码、SSM项目源码、微信小程序源码 精品专栏&#xff1a;…

DELL R720服务器阵列数据恢复,磁盘状态为Foreign

服务器无法正常进入系统&#xff0c;物理磁盘状态变成了Foreign 虚拟磁盘状态变成了Failed 阵列已经丢失了&#xff0c;需要手工强制导入外部配置 单击 Main Menu 屏幕上的 Configuration Management。单击 Manage Foreign Configuration 单击 Preview Foreign Configurati…

60. 排列序列【回溯】

文章目录 60. 排列序列解题思路Go代码 60. 排列序列 60. 排列序列 给出集合 [1,2,3,...,n]&#xff0c;其所有元素共有 n! 种排列。 按大小顺序列出所有排列情况&#xff0c;并一一标记&#xff0c;当 n 3 时, 所有排列如下&#xff1a; “123”“132”“213”“231”“31…

VMDK 0X80BB0005 VirtualBOX虚拟机错误处理-数据恢复——未来之窗数据恢复

打开虚拟盘文件in7.vmdk 失败. Could not get the storage format of the medium 7\win7.vmdk (VERR_NOT_SUPPORTED). 返回 代码:VBOX_E_IPRT_ERROR (0X80BB0005) 组件:MediumWrap 界面:IMedium {a a3f2dfb1} 被召者:IVirtualBox {768 cd607} 被召者 RC:VBOX_E_OBJECT_NOT_F…

Qt基础对话框QDialog

模态显示对话框 调用exec方法可以使得对话框模态显示&#xff0c;但是一个阻塞函数 [virtual slot] int QDialog::exec() 对话框的三个槽函数 accept [virtual slot] void QDialog::accept(); reject [virtual slot] void QDialog::reject() done [virtual slot] void QDia…

Nginx从入门到实战(八):版本平滑无感知,不停机升级

一、查看旧版本信息 可以通过nginx -V命令&#xff0c;来查看当前nginx的版本信息&#xff0c;和配置参数。 [rootnb001 sbin]# nginx -V -bash: nginx: command not found [rootnb001 sbin]# ./nginx -V nginx version: nginx/1.20.1 built by gcc 4.8.5 20150623 (Red Hat …

Spring Boot读取resources目录下文件(打成jar可用),并放入Guava缓存

1、文件所在位置&#xff1a; 2、需要Guava依赖&#xff1a; <dependency><groupId>com.google.guava</groupId><artifactId>guava</artifactId><version>23.0</version></dependency>3、启动时就读取放入缓存的代码&#xf…

gaussdb hccdp理论考试总结

判断题1分&#xff0c;单选题2分&#xff0c;多选题3分 共50道题&#xff0c;满分100分&#xff0c;60分通过。 理论考试知识点占比&#xff1a; 理论考试参考策略&#xff1a; 1.7张PPT看一遍 2.思考题做一遍 3.模拟题做一遍 4.7张PPT再看一遍 5.考题知识点过一遍 6.考试前一…

ZYNQ使用XGPIO驱动外设模块(前半部分)

目录 目录 一、新建BD文档&#xff0c;添加ZYNQ处理器 1.BD文档: 2.在Vivado中&#xff0c;BD文件的生成过程通常包括以下步骤&#xff1a; 1)什么是Tcl Console: 3.PL部分是FPGA可编程逻辑部分&#xff0c;它提供了丰富的IO资源&#xff0c;可以用于实现各种硬件接口和功…

QT 连接SQL SEVER 之后无法读取浮点和整型

1、ODBC Driver 的版本要对应上。 if (!strDbDirPath.isEmpty())m_strDbDirPath strDbDirPath;m_strDatabaseName strDatabaseName;if (m_database.isOpen() || m_bConnected){qDebug() << QString("QODBC:已经连接成功&#xff01;") << "\n&quo…

Power Pivot, PowerView和PowerBI在产品宣传,功能,及本质上有什么不同?

微软的Power Pivot、Power View和Power BI是三个不同的数据分析和商业智能工具&#xff0c;它们在产品宣传、功能和本质上有所区别&#xff0c;并且各自适用于不同的场景。 1. Power Pivot Power Pivot是一种数据建模技术&#xff0c;用于在Excel中创建数据模型&#xff0c;建…

Halcon 3D应用 - 胶路提取

1. 需求 本文基于某手环&#xff08;拆机打磨处理&#xff09;做的验证性工作&#xff0c;为了项目保密性&#xff0c;只截取部分数据进行测试。 这里使用的是海康3D线激光轮廓相机直线电机的方式进行的高度数据采集&#xff0c;我们拿到的是高度图亮度图数据。 提取手环上的胶…

Java面向对象编程--高级

目录 一、static关键字 1.1 静态变量 1.2 静态内存解析 1.3 static的应用与练习 二、单例设计模式 2.1 单例模式 2.2 如何实现单例模式 三、代码块 3.1 详解 3.2 练习&#xff0c;测试 四、final关键字 五、抽象类与抽象方法 5.1 abstract 5.2 练习 六、接口 6.…

d3dcompiler_47.dll缺失怎么修复,马上教你六种靠谱的方法

在使用计算机的过程中&#xff0c;我们可能会遇到各种问题&#xff0c;其中一个就是某些dll文件缺失。比如d3dcompiler_47.dll&#xff0c;这个文件是DirectX的一部分&#xff0c;主要用于编译DirectX的着色器代码。当这个文件缺失时&#xff0c;一些程序就无法正常运行了&…