`

使用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;
	//视频资源ID
	private 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;
	}
	@Override
	public 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文件解析信息获取资源id
				List<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,以后有时间再写一篇吧!希望能帮到需要的人,哈哈!有写的不对的希望高手可以指点一下!谢谢!
 

  • 大小: 40 KB
  • 大小: 43.6 KB
  • 大小: 53 KB
分享到:
评论

相关推荐

    用Jxls实现数据导入excel实例

    本文将详细介绍如何使用Jxls实现数据导入Excel的实例。 Jxls库的核心功能在于提供了一种声明式的方式来处理Excel模板,通过使用Apache POI库来操作Excel文件。它的主要优点是将数据和样式分离,让开发者可以专注于...

    使用 jxls2.X 导出excel文件

    jxls是一个开源的Java库,其主要功能是允许开发者使用标准的JSP标签语法来定义Excel模板,并在运行时填充这些模板。jxls2提供了更多的特性,如支持多线程、更灵活的数据映射和更丰富的内置函数,使得处理复杂的数据...

    jxls模板导出Excel所需jar包

    而jxls则在POI的基础上添加了对模板处理的支持,使得开发者可以使用类似于JSP的语法在Excel模板中动态插入数据。 要使用jxls,你需要引入相应的jar包。"jxls使用模板导出excel"这个压缩包可能包含了以下核心组件的...

    SpringBoot(33) 整合JXLS实现Excel导入导出

    2. **创建Excel模板**:使用Microsoft Excel创建一个模板文件,定义好所需的样式和布局。JXLS会根据模板和提供的数据来生成Excel文件。 3. **编写Java代码**:创建一个服务类,定义方法来处理Excel的导入和导出。...

    jxls导入导出

    **jxls导入导出**是Java开发中处理Excel数据与数据库交互的一种技术,它基于Apache POI库,提供了方便快捷的方式来导入Excel数据到数据库以及从数据库导出数据到Excel文件。这种技术尤其适用于批量处理数据或者创建...

    利用jxls操作excel模板文件

    在Java开发中,处理Excel...通过以上步骤,你就可以在Java项目中灵活地利用Jxls库来处理Excel模板文件,实现数据的导入导出和报表生成等功能。熟练掌握Jxls的使用,能极大地提高开发效率,让Excel操作变得简单易行。

    JXLS导入导出示例

    1. **JXLS导入导出原理** JXLS的核心思想是通过定义一个Excel模板,这个模板包含了数据呈现的样式和布局。在导入时,JXLS会根据模板读取Excel数据,并将其转化为Java对象。在导出时,它将Java对象的数据填充到模板...

    jxls-导入导出-java

    `jxls`扩展了POI的功能,使得我们可以使用类似于JSP的语法来定义Excel模板,然后通过Java代码动态填充这些模板,生成复杂的Excel表格。 在"jxls例子"中,我们可以看到如何利用`jxls`进行实际操作。首先,你需要创建...

    jxl 读取Excel模板并写入数据通用工具类

    本文将详细讨论如何使用JXL库创建一个通用的工具类来读取Excel模板并填充数据。 首先,我们需要了解JXL库的基本用法。JXL库提供了多种API,可以用来操作Excel文件的各个部分,包括工作簿(Workbook)、工作表...

    java web使用jxls导出excel功能

    Jxls库提供了灵活的模板机制,使得数据与格式分离,使得Excel模板的设计和维护变得更加简单。同时,由于Jxls是基于Apache POI实现的,因此它支持多种版本的Excel文件,包括老式的`.xls`和现代的`.xlsx`格式。

    jxls 基于模版导出excel

    jxls的核心理念是将Excel模板与Java对象绑定,通过模板语言(如Freemarker)来动态填充数据,从而实现数据的自动化导出。 **jxls核心组件** 1. **jxls-core-1.0.jar**:这是jxls的核心库,包含了处理Excel模板和...

    jxls导出excel官方例子

    jxls(Java eXcel Library)是一个强大的库,它允许开发者使用Java模板语言来处理Excel文档,极大地简化了Excel数据的导入和导出操作。本篇文章将深入探讨jxls库,并通过官方示例,帮助你掌握如何高效地使用jxls导出...

    jxls实现的excel导出功能,支持03以上版本

    jxls是一个强大的Java库,它允许开发者使用Apache POI库来处理Excel模板,从而简化Excel数据导出的过程。这个功能特别适用于需要将大量结构化数据转换为易于阅读的Excel格式的情况,比如报告、数据分析或用户导出的...

    jxls 读写Excel

    它提供了方便的方式来动态地生成和填充Excel模板,适用于数据报告、批量数据导入导出等场景。 描述中的“jxls实现例子”暗示了该博客文章可能包含如何使用jxls的实际示例代码或步骤,通过访问提供的链接(已省略,...

    jxls导excel所需的所有jar包

    1. **jxls-2.x.jar**: 这是JXLS的主要库,包含了处理Excel模板和数据的核心类和接口。它提供了如`JexlHelper`、`AreaReference`、`CellProcessorFactory`等工具,用于解析模板、执行表达式和转换数据。 2. **jxls-...

    通过jxls和poi导出excel的dome

    3. **数据准备**:根据业务需求,创建Java对象和集合,这些对象将作为数据源填充到Excel模板中。 4. **配置jxls处理器**:设置jxls的工作流,这包括设置模板、数据源、输出流等参数。 5. **应用jxls转换**:使用`...

    excel模板所需jar:commons-jexl-2.1.1.jar 和 jxls-core1.0.3.jar

    本文将详细阐述`jxls`库以及与之相关的`commons-jexl-2.1.1.jar`和`jxls-core1.0.3.jar`这两个关键的Java库,以及它们如何协同工作来实现Excel模板的动态数据填充。 `jxls`是一个Java库,它的主要功能是帮助开发者...

    jxls实现Excel表格

    - **添加指令**:jxls支持在Excel模板中使用特定的指令(如`jx:each`、`jx:if`等)来控制数据的填充逻辑。 - **准备数据**:在Java代码中,我们需要准备要填充到模板中的数据集合,这些数据可以是List、Map或者其他...

    jxls导入demo案例

    在这个“jxls导入demo案例”中,我们将探讨如何使用`jxls`库来实现从Excel文件中导入数据到Java应用程序。以下是一些关键知识点: 1. **Apache POI**: 首先,`jxls`是建立在Apache POI之上的,POI是Java社区开发的...

    JXLS 2.4.0 excel 导出 可以运行在 JDK 1.6

    JXLS 2.4.0支持自定义函数的调用,使得在Excel模板中插入这些函数变得简单,提高了数据处理的灵活性。 数据格式化是另一个值得一提的特性。在Excel中,我们可以设置单元格的样式,包括字体、颜色、对齐方式、边框和...

Global site tag (gtag.js) - Google Analytics