使用jxls技术导入Excel模版数据

2024-05-13 19:08

本文主要是介绍使用jxls技术导入Excel模版数据,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

 

今天接到一个需求,要求我把Excel中的数据导入java程序中作为查询条件,查询数据在做业务逻辑处理,刚接到任务第一反应用poi解析Excel获取数据,后来想想,我们的项目中之前导出都是用的jxls实现,而且还挺方便的jxls还有自己的标签(虽然标签有点坑),就想着有导出功能jxls肯定也有导入功能啦!尝试使用jxls导入,发现确实比我以前用poi自己手写方便多了,下面是部分代码及过程说明!

 

第一步:先确定好Excel导入的格式以及各表格字段值含义


 

第二步:定义好解析的XML--videoConfig.xml

 

 

<?xml version="1.0" encoding="UTF-8"?> 
<workbook> <worksheet name="Sheet1"> <section startRow="0" endRow="0"/> <loop startRow="1" endRow="1" items="videoInfoList" var="videoInfo" varType="com.iflytek.weike.job.bo.VideoInfo"> <section startRow="1" endRow="1"> <mapping row="1" col="0">videoInfo.index</mapping> <mapping row="1" col="1">videoInfo.videoName</mapping> <mapping row="1" col="2">videoInfo.resourceId</mapping> <mapping row="1" col="3">videoInfo.upload</mapping> <mapping row="1" col="4">videoInfo.content</mapping> <mapping row="1" col="5">videoInfo.schoolName</mapping></section> <loopbreakcondition> <rowcheck offset="0"><cellcheck offset="0"></cellcheck> </rowcheck> </loopbreakcondition> </loop> </worksheet> 
</workbook>

 

 第三步:生成一下解析的实体类VideoInfo(这个需要根据excel文件的列去手工写一个)

 

public class VideoInfo {//序号private int index;//视频名称(全称)private String videoName;//视频资源IDprivate String resourceId;//上传者private String upload;//课程说明private String content;//学校名称private String schoolName;public VideoInfo() {}public VideoInfo(int index, String videoName, String resourceId, String upload, String content, String schoolName) {super();this.index = index;this.videoName = videoName;this.resourceId = resourceId;this.upload = upload;this.content = content;this.schoolName = schoolName;}public int getIndex() {return index;}public void setIndex(int index) {this.index = index;}public String getVideoName() {return videoName;}public void setVideoName(String videoName) {this.videoName = videoName;}public String getResourceId() {return resourceId;}public void setResourceId(String resourceId) {this.resourceId = resourceId;}public String getUpload() {return upload;}public void setUpload(String upload) {this.upload = upload;}public String getContent() {return content;}public void setContent(String content) {this.content = content;}public String getSchoolName() {return schoolName;}public void setSchoolName(String schoolName) {this.schoolName = schoolName;}@Overridepublic String toString() {return "VideoInfo [index=" + index + ", videoName=" + videoName + ", resourceId=" + resourceId + ", upload="+ upload + ", content=" + content + ", schoolName=" + schoolName + "]";}}

 
 第四步:添加jxls的jar包,我这里项目用maven管理jar包的版本是1.0.6大家可以去下面这个maven资源库下                载jar包  maven资源库地址:http://mvnrepository.com/open-source/excel-libraries;

 

第五步:windows弹框选择文件并解析Excel数据,这个windows文件框选择文件我以前还是真没做过在网上               找了一个很好用的方法请看代码:

/*** 打开文件选择窗口选择导入文件* @return 返回文件路径* @throws Exception*/public String getExcelPath() throws Exception{UIManager.setLookAndFeel(UIManager.getSystemLookAndFeelClassName());JFileChooser jFileChooser=new JFileChooser();int i = jFileChooser.showOpenDialog(null); if(i== jFileChooser.APPROVE_OPTION){ //打开文件                        String path = jFileChooser.getSelectedFile().getAbsolutePath();String fileName = jFileChooser.getSelectedFile().getName();String extName =fileName.substring(fileName.lastIndexOf(".")+1,fileName.length());System.out.println("当前文件路径:"+path+";\n当前文件名:"+fileName+";\n当前文件扩展名:"+extName);if(null!=extName&&"xlsx".equals(extName)){return path;}else{System.out.println("您好,只能导入扩展名为xlsx的Excel文件!");return null;}}else{System.out.println("没有选中文件");return null;}
}/*** 使用jxls解析导入的Excel* @param path 导入文件路径* @return List<VideoInfo> 导入对象集合*/public List<VideoInfo> getExcelDataForVideoInfo(String path){List<VideoInfo> videoInfoList = new ArrayList<VideoInfo>();try {InputStream inputXML = new BufferedInputStream(getClass().getClassLoader().getResourceAsStream(ConsForSystem.XML_CONFIG));XLSReader mainReader = ReaderBuilder.buildFromXML( inputXML );InputStream inputXLS = new BufferedInputStream(new FileInputStream(new File(path)));VideoInfo videoInfo = new VideoInfo();Map<String,Object> beans = new HashMap<String,Object>();beans.put("videoInfo", videoInfo);beans.put("videoInfoList", videoInfoList);XLSReadStatus readStatus = mainReader.read( inputXLS, beans);if(readStatus.isStatusOK()){System.out.println("jxls读取Excel成功!");}} catch (Exception e) {e.printStackTrace();}return videoInfoList;}

    其中有个静态变量我是统一写在配置类中的:

     public static String XML_CONFIG ="videoConfig.xml";

 

     第六步:写一个main函数执行我们写好的方法试一下

     

public class Test {public static void main(String[] args) {SyncDataServiceImpl syncDataService = new SyncDataServiceImpl();try {String filePath = syncDataService.getExcelPath();if(null!=filePath&&StringUtils.isNotBlank(filePath)){//导入Excel文件解析信息获取资源idList<VideoInfo> infoList = syncDataService.getExcelDataForVideoInfo(filePath);System.out.println("infoList大小==="+infoList.size());for(VideoInfo video:infoList){System.out.println("打印ideoInfo详细信息======"+video.toString());}}} catch (Exception e) {e.printStackTrace();}}
}

 

    其中SyncDataServiceImpl类是我把前面二个方法写到这个类里面了,里面还有一些其他的业务处理逻辑,就不贴上来了, new SyncDataServiceImpl()对象就可以调用刚才的方法了!

 下面的运行截图:

 

 

 运行结果截图,导入Excel成功:



 
相比较POI来读取Excel数据个人觉得jxls用起来还是更方便一点!同时jxls导出Excel也是比较方便的,有自己的标签类似JSTL,以后有时间再写一篇吧!希望能帮到需要的人,哈哈!有写的不对的希望高手可以指点一下!谢谢!
 

这篇关于使用jxls技术导入Excel模版数据的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/986573

相关文章

Spring IoC 容器的使用详解(最新整理)

《SpringIoC容器的使用详解(最新整理)》文章介绍了Spring框架中的应用分层思想与IoC容器原理,通过分层解耦业务逻辑、数据访问等模块,IoC容器利用@Component注解管理Bean... 目录1. 应用分层2. IoC 的介绍3. IoC 容器的使用3.1. bean 的存储3.2. 方法注

MySQL 删除数据详解(最新整理)

《MySQL删除数据详解(最新整理)》:本文主要介绍MySQL删除数据的相关知识,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录一、前言二、mysql 中的三种删除方式1.DELETE语句✅ 基本语法: 示例:2.TRUNCATE语句✅ 基本语

Python内置函数之classmethod函数使用详解

《Python内置函数之classmethod函数使用详解》:本文主要介绍Python内置函数之classmethod函数使用方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地... 目录1. 类方法定义与基本语法2. 类方法 vs 实例方法 vs 静态方法3. 核心特性与用法(1编程客

Linux中压缩、网络传输与系统监控工具的使用完整指南

《Linux中压缩、网络传输与系统监控工具的使用完整指南》在Linux系统管理中,压缩与传输工具是数据备份和远程协作的桥梁,而系统监控工具则是保障服务器稳定运行的眼睛,下面小编就来和大家详细介绍一下它... 目录引言一、压缩与解压:数据存储与传输的优化核心1. zip/unzip:通用压缩格式的便捷操作2.

使用Python实现可恢复式多线程下载器

《使用Python实现可恢复式多线程下载器》在数字时代,大文件下载已成为日常操作,本文将手把手教你用Python打造专业级下载器,实现断点续传,多线程加速,速度限制等功能,感兴趣的小伙伴可以了解下... 目录一、智能续传:从崩溃边缘抢救进度二、多线程加速:榨干网络带宽三、速度控制:做网络的好邻居四、终端交互

Python中注释使用方法举例详解

《Python中注释使用方法举例详解》在Python编程语言中注释是必不可少的一部分,它有助于提高代码的可读性和维护性,:本文主要介绍Python中注释使用方法的相关资料,需要的朋友可以参考下... 目录一、前言二、什么是注释?示例:三、单行注释语法:以 China编程# 开头,后面的内容为注释内容示例:示例:四

Java easyExcel实现导入多sheet的Excel

《JavaeasyExcel实现导入多sheet的Excel》这篇文章主要为大家详细介绍了如何使用JavaeasyExcel实现导入多sheet的Excel,文中的示例代码讲解详细,感兴趣的小伙伴可... 目录1.官网2.Excel样式3.代码1.官网easyExcel官网2.Excel样式3.代码

Go语言数据库编程GORM 的基本使用详解

《Go语言数据库编程GORM的基本使用详解》GORM是Go语言流行的ORM框架,封装database/sql,支持自动迁移、关联、事务等,提供CRUD、条件查询、钩子函数、日志等功能,简化数据库操作... 目录一、安装与初始化1. 安装 GORM 及数据库驱动2. 建立数据库连接二、定义模型结构体三、自动迁

MyBatisPlus如何优化千万级数据的CRUD

《MyBatisPlus如何优化千万级数据的CRUD》最近负责的一个项目,数据库表量级破千万,每次执行CRUD都像走钢丝,稍有不慎就引起数据库报警,本文就结合这个项目的实战经验,聊聊MyBatisPl... 目录背景一、MyBATis Plus 简介二、千万级数据的挑战三、优化 CRUD 的关键策略1. 查

python实现对数据公钥加密与私钥解密

《python实现对数据公钥加密与私钥解密》这篇文章主要为大家详细介绍了如何使用python实现对数据公钥加密与私钥解密,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录公钥私钥的生成使用公钥加密使用私钥解密公钥私钥的生成这一部分,使用python生成公钥与私钥,然后保存在两个文