当前位置: 首页 > news >正文

EASYEXCEL(一)

1.读取excel

读监听器


@Slf4j
public class StudentReadListener extends AnalysisEventListener<Student> {// 每读一样,会调用该invoke方法一次@Overridepublic void invoke(Student data, AnalysisContext context) {System.out.println("data = " + data);log.info(data + "保存成功");}// 全部读完之后,会调用该方法@Overridepublic void doAfterAllAnalysed(AnalysisContext context) {// TODO......}
}

映射实体类


@Data
@AllArgsConstructor
@NoArgsConstructor
@ColumnWidth(20)
@ToString
public class Student {/*** id*/@ExcelProperty(value = "编号",index = 0)//@ExcelIgnoreprivate String id;/*** 学生姓名*/@ExcelProperty(value = "学生姓名", index = 1)//@ColumnWidth(30)private String name;/*** 学生性别*/@ExcelProperty(value = "学生性别", index = 2)private String gender;/*** 学生出生日期*/@ExcelProperty(value = "学生出生日期", index = 3)//@ColumnWidth(20)private Date birthday;

 读取

public class StudentReadDemo {public static void main(String[] args) throws FileNotFoundException {// 读取文件,读取完之后会自动关闭/*pathName        文件路径;"C:\\Users\\wjg\\Desktop\\学员信息.xlsx"head            每行数据对应的实体;Student.classreadListener    读监听器,每读一样就会调用一次该监听器的invoke方法sheet方法参数: 工作表的顺序号(从0开始)或者工作表的名字,不传默认为0*/// 封装工作簿对象ExcelReaderBuilder workBook = EasyExcel.read("C:\\Users\\wjg\\Desktop\\学员信息.xlsx", Student.class, new StudentReadListener());// 封装工作表ExcelReaderSheetBuilder sheet1 = workBook.sheet();// 读取sheet1.doRead();}

2.写入excel

public class StudentWriteDemo {public static void main(String[] args) {List<Student> students = initData();/*String pathName 写入文件的路径Class head      写入文件的对象类型默认写入到07的xlsx中,如果想要写入xls,可以指定类型(待验证)*/ExcelWriterBuilder workBook = EasyExcel.write("C:\\Users\\wjg\\Desktop\\学员信息.xlsx", Student.class);// sheet方法参数: 工作表的顺序号(从0开始)或者工作表的名字workBook.sheet().doWrite(students);}private static List<Student> initData() {ArrayList<Student> students = new ArrayList<Student>();Student data = new Student();for (int i = 0; i < 10; i++) {data.setName("学号0" + i);data.setBirthday(new Date());data.setGender("男");data.setId(String.valueOf(i));students.add(data);}return students;}
}

相关文章:

EASYEXCEL(一)

1.读取excel 读监听器 Slf4j public class StudentReadListener extends AnalysisEventListener<Student> {// 每读一样&#xff0c;会调用该invoke方法一次Overridepublic void invoke(Student data, AnalysisContext context) {System.out.println("data "…...

竞赛YOLOv7 目标检测网络解读

文章目录 0 前言1 yolov7的整体结构2 关键点 - backbone关键点 - head3 训练4 使用效果5 最后 0 前言 世界变化太快&#xff0c;YOLOv6还没用熟YOLOv7就来了&#xff0c;如果有同学的毕设项目想用上最新的技术&#xff0c;不妨看看学长的这篇文章&#xff0c;学长带大家简单的…...

第一类曲线积分@对弧长的曲线积分

文章目录 abstract对弧长的曲线积分曲线形构件的质量第一类曲线积分曲线积分存在性利用曲线积分的定义描述曲线形构件质量问题推广曲线积分可加性闭曲线积分 曲线积分性质曲线积分的计算方法证明(部分推导) 小结曲线弧显函数形式方程下的曲线积分公式推广例例例 abstract 在积…...

【TypeScript】常见数据结构与算法(二):链表

文章目录 链表结构&#xff08;LinkedList&#xff09;链表以及数组的缺点数组链表的优势 什么是链表?封装链表相关方法源码链表常见面试题237-删除链表中的节点206 - 反转链表 数组和链表的复杂度对比 链表结构&#xff08;LinkedList&#xff09; 链表以及数组的缺点 链表…...

原型模式 (Prototype Pattern)

定义&#xff1a; 原型模式&#xff08;Prototype Pattern&#xff09;是一种创建型设计模式&#xff0c;它用于创建重复的对象&#xff0c;同时保持性能。这种模式的核心思想是通过复制一个已存在的实例来创建新的实例&#xff0c;而不是新建实例并对其进行初始化。原型模式适…...

项目总结报告(案例模板)

软件项目总结报告模板套用&#xff1a; 项目概要项目工作分析经验与教训改进建议可纳入的项目过程资产 --------进主页获取更多资料-------...

C++ Qt QByteArray用法介绍

作者:令狐掌门 技术交流QQ群:675120140 csdn博客:https://mingshiqiang.blog.csdn.net/ 文章目录 一、QByteArray的基本用法1、初始化和赋值2、访问和修改元素3、 常用方法4、数据转换二、QByteArray与文件操作三、QByteArray与网络编程四、QByteArray数据编码1、Base64 编解…...

蓝桥杯物联网竞赛_STM32L071_3_Oled显示

地位&#xff1a; 对于任何一门编程语言的学习&#xff0c;print函数毫无疑问是一种最好的调试手段&#xff0c;调试者不仅能通过它获取程序变量的运行状态而且通过对其合理使用获取程序的运行流程&#xff0c;更能通过关键变量的输出帮你验证推理的正确与否&#xff0c;朴素的…...

python-opencv轮廓检测(外轮廓检测和全部轮廓检测,计算轮廓面积和周长)

python-opencv轮廓检测&#xff08;外轮廓检测和全部轮廓检测&#xff0c;计算轮廓面积和周长&#xff09; 通过cv2.findContours&#xff0c;我们可以进行轮廓检测&#xff0c;当然也有很多检测模式&#xff0c;我们可以通过选择检测模式&#xff0c;进行外轮廓检测&#xff…...

LeetCode [简单] 1. 两数之和

给定一个整数数组 nums 和一个整数目标值 target&#xff0c;请你在该数组中找出 和为目标值 target 的那 两个 整数&#xff0c;并返回它们的数组下标。 你可以假设每种输入只会对应一个答案。但是&#xff0c;数组中同一个元素在答案里不能重复出现。 你可以按任意顺序返回…...

C++设计模式之工厂模式(下)——抽象工厂模式

抽象工厂模式 介绍示例示例使用运行结果抽象工厂模式的优缺点优点缺点 总结 介绍 抽象工厂模式是一种创建型设计模式&#xff0c;它提供了一种封装一组相关或相互依赖对象的方式&#xff0c;而无需指定它们具体的类。它允许客户端使用抽象接口来创建一系列相关的对象&#xff…...

2023亚太杯数学建模A题思路分析 - 采果机器人的图像识别技术

1 赛题 问题A 采果机器人的图像识别技术 中国是世界上最大的苹果生产国&#xff0c;年产量约为3500万吨。与此同时&#xff0c;中国也是世 界上最大的苹果出口国&#xff0c;全球每两个苹果中就有一个&#xff0c;全球超过六分之一的苹果出口 自中国。中国提出了一带一路倡议…...

关于Flink的旁路缓存与异步操作

1. 旁路缓存 1. 什么是旁路缓存? 将数据库中的数据,比较经常访问的数据,保存起来,以减少和硬盘数据库的交互 比如: 我们使用mysql时 经常查询一个表 , 而这个表又一般不会变化,就可以放在内存中,查找时直接对内存进行查找,而不需要再和mysql交互 2. 旁路缓存例子使用 dim层…...

MyBatis-Plus的分页插件和乐观锁插件

MyBatis-Plus: 探索分页查询和乐观锁插件 在现代的Web应用开发中&#xff0c;高效的数据处理是不可或缺的一部分。MyBatis-Plus&#xff0c;作为MyBatis的增强版&#xff0c;提供了多种插件来简化和优化数据库操作。在这篇博客中&#xff0c;我们将重点介绍两个非常实用的插件…...

批量将本地N个英文Html文档进行中文翻译-操作篇

Unity3D特效百例案例项目实战源码Android-Unity实战问题汇总游戏脚本-辅助自动化Android控件全解手册再战Android系列Scratch编程案例软考全系列Unity3D学习专栏蓝桥系列ChatGPT和AIGC &#x1f449;关于作者 专注于Android/Unity和各种游戏开发技巧&#xff0c;以及各种资源分…...

解决cad找不到vcruntime140.dll的方法,实测有效的5个的方法

最近&#xff0c;我在使用CAD软件时遇到了一个困扰我已久的问题&#xff1a;由于找不到vcruntime140.dll文件而导致CAD无法正常运行。经过一番努力和尝试&#xff0c;我终于找到了解决这个问题的方法。那么&#xff0c;如何解决vcruntime140.dll丢失的问题呢&#xff1f;本文将…...

2023亚太杯数学建模C题:我国新能源电动汽车的发展趋势,思路模型代码

问题C 我国新能源电动汽车的发展趋势 赛题思路&#xff1a;获取思路见文末名片&#xff0c;第一时间更新 新能源汽车是指以先进技术原理、新技术、新结构的非常规汽车燃料为动力来源( 非常规汽车燃料指汽油、柴油以外的燃料&#xff09;&#xff0c;将先进技术进行汽车动力控制…...

英语学习-爆破音

英文爆破音有&#xff1a;[p],[b],[t],[d],[k],[g]。 同时爆破音的发音会根据前后音的不同&#xff0c;发音不同&#xff0c;具体如下&#xff1a; ⒈ [p],[b],[t],[d],[k],[g] 中的任何两个音素相邻时&#xff0c;前面的发不完全爆破音&#xff0c;后面的就要完全地爆破。如…...

【Vue】图片切换

上一篇&#xff1a; vue的指令 https://blog.csdn.net/m0_67930426/article/details/134599378?spm1001.2014.3001.5502 本篇所需要的指令有&#xff1a; v-on v-bind v-show <!DOCTYPE html> <html lang"en"> <head><meta charset"…...

C++模拟如何实现vector的方法

任意位置插入&#xff0c;insert的返回值为新插入的第一个元素位置的迭代器&#xff1b;因为插入可能会进行扩容&#xff0c;导致start的值改变&#xff0c;所以先定义一个变量保存pos与start的相对位置&#xff1b;判断是否需要扩容&#xff1b;从插入位置开始&#xff0c;将所…...

Mujoco+强化学习入门实战教程

前言&#xff1a;本文是为了方便机器人初学者快速学习Mujoco强化学习而设计的教程&#xff0c;循序渐进&#xff0c;从环境搭建到简单的运动控制再到强化学习自主探索&#xff0c;难度逐步提升&#xff0c;帮助初学者建立学习路线&#xff0c;思维框架&#xff0c;并在此基础上…...

LFM2.5-VL-1.6B实操手册:如何用PIL调整输入图尺寸适配512x512分块要求

LFM2.5-VL-1.6B实操手册&#xff1a;如何用PIL调整输入图尺寸适配512x512分块要求 1. 模型概述 LFM2.5-VL-1.6B是由Liquid AI开发的轻量级多模态大模型&#xff0c;专为端侧和边缘设备设计。该模型结合了1.2B参数的语言模型和约400M参数的视觉模型&#xff0c;能够在低显存环…...

Ubuntu 22.04 + Python 3.10 保姆级教程:手把手搞定nnUNetV2环境配置与MSD数据集转换

Ubuntu 22.04 Python 3.10 实战指南&#xff1a;nnUNetV2环境配置与MSD数据集高效转换全流程 在医学图像分割领域&#xff0c;nnUNetV2以其出色的自适应能力和稳定的性能表现&#xff0c;已成为众多研究团队的首选框架。然而对于刚接触该框架的研究人员和开发者而言&#xff…...

别再只盯着电感了!聊聊手机快充和LED驱动里,那颗‘会飞’的电容是怎么把电压‘泵’上去的

手机快充背后的隐形功臣&#xff1a;揭秘电荷泵如何用一颗电容实现高效升压 当你的手机在半小时内从0%充到80%时&#xff0c;背后隐藏着一项被大多数人忽视的黑科技——电荷泵。这种没有电感、仅靠电容"飞行"来传递能量的DC-DC转换器&#xff0c;正在悄然改变消费电子…...

收藏必备!小白程序员轻松入门大模型微调实战(含Prompt-tuning、Adapter-tuning等)

本文介绍了大模型微调的重要性及其基本流程&#xff0c;重点讲解了参数高效微调&#xff08;PEFT&#xff09;方法&#xff0c;包括参数附加方法&#xff08;如Prompt-tuning、Adapter-tuning、Prefix-tuning、Proxy-tuning&#xff09;、参数选择方法&#xff08;如BitFit、Ch…...

保姆级教程:在Abaqus/CAE中为单向复合材料手动与脚本定义局部坐标系(附横观各向同性参数计算)

复合材料仿真实战&#xff1a;Abaqus局部坐标系定义与横观各向同性参数解析 在复合材料有限元分析中&#xff0c;准确描述纤维取向是仿真的关键第一步。许多工程师在使用Abaqus时会遇到这样的困境&#xff1a;明明按照教程设置了材料参数&#xff0c;但仿真结果却与实验数据存在…...

OpenBoardView:完全免费的.brd电路板文件查看终极指南

OpenBoardView&#xff1a;完全免费的.brd电路板文件查看终极指南 【免费下载链接】OpenBoardView View .brd files 项目地址: https://gitcode.com/gh_mirrors/op/OpenBoardView 还在为昂贵的电路板设计软件而烦恼吗&#xff1f;想要一款真正免费、跨平台、功能强大的.…...

别再死记硬背了!用C语言递归搞定二叉树遍历转换(PTA真题7-1保姆级解析)

从手算到代码&#xff1a;二叉树遍历转换的思维跃迁 当你在PTA或LeetCode上遇到"已知后序和中序遍历求先序遍历"这类题目时&#xff0c;是否也曾陷入"先建树再遍历"的思维定式&#xff1f;实际上&#xff0c;这类问题的核心在于发现遍历序列间的隐藏规律&a…...

免费在线游戏手柄检测工具:3分钟快速诊断手柄按键故障

免费在线游戏手柄检测工具&#xff1a;3分钟快速诊断手柄按键故障 【免费下载链接】gamepadtest Gamepad API Test 项目地址: https://gitcode.com/gh_mirrors/ga/gamepadtest 还在为游戏手柄按键失灵而烦恼吗&#xff1f;这款免费的在线游戏手柄测试工具能帮你快速诊断…...

WinUtil:Windows系统优化与管理的全栈解决方案,提升系统效率50%以上

WinUtil&#xff1a;Windows系统优化与管理的全栈解决方案&#xff0c;提升系统效率50%以上 【免费下载链接】winutil Chris Titus Techs Windows Utility - Install Programs, Tweaks, Fixes, and Updates 项目地址: https://gitcode.com/GitHub_Trending/wi/winutil W…...