当前位置: 首页 > 软件库 > 程序开发 > Excel开发包 >

JxlExcel

Java Excel 读写库
授权协议 MIT
开发语言 Java
所属分类 程序开发、 Excel开发包
软件类型 开源软件
地区 国产
投 递 者 翁凯定
操作系统 跨平台
开源组织
适用人群 未知
 软件概览

JxlExcel 是基于jxl封装的java excel读写库,特性如下:

  • 可以像读写文件一样方便的读取数据和写入数据

  • 数据支持数组、map、bean三种方式

  • 支持xml配置excel模板

如何使用?

模板定义

在类路径下新建一个jxl-excel.xml的模板配置文件,输入如下的配置文件内容,即可定义一个excel模板。

<?xml version="1.0" encoding="UTF-8" ?>
<templates>
<template name="testRead">
    <titleRow>
        <titleCol span="6">span标题</titleCol>
    </titleRow>
    <titleRow>
        <titleCol>编制单位(盖章):</titleCol>
        <titleCol></titleCol>
        <titleCol span="3">编制日期:</titleCol>
        <titleCol>单位:元</titleCol>
    </titleRow>
    <titleRow>
        <titleCol>地区</titleCol>
        <titleCol>姓名</titleCol>
        <titleCol>身份证</titleCol>
        <titleCol>账号</titleCol>
        <titleCol>金额</titleCol>
        <titleCol>备注</titleCol>
    </titleRow>
    <dataRow>
        <dataCol>area</dataCol>
        <dataCol>name</dataCol>
        <dataCol>idCard</dataCol>
        <dataCol>bankAccount</dataCol>
        <dataCol>amount</dataCol>
        <dataCol>remark</dataCol>
    </dataRow>
</template>
</templates>
  • 模板(template)

    template元素用于定义一个模板,包含一个属性name,用于唯一标识该模板

  • 标题行(tittleRow)

    使用titleRow可以定义多行标题,每行标题又包含多个标题列(titleCol),标题列可以像html table的td一样定义span属性,表示该列占用几列空间

  • 数据行(dataRow)

    数据行用于定义Java bean或者Map中的属性在模板中的显示或读写顺序,数据行中的dataCol不支持span

读数据

InputStream is = JxlExcelReaderTest.class
            .getResourceAsStream("/testRead.xls");
reader.setExcelTemplate("testRead");
List<String[]> datas = reader.readArrays();
//List<Account> beans = reader.readBeans(Account.class);
//List<Map<String, Object>> maps = reader.readMaps();

写数据

File tmp = new File("testWriteData.xls");
if (tmp.exists()) {
tmp.delete();
}
tmp.createNewFile();
JxlExcelWriter jxlExcelWriter = new JxlExcelWriter(tmp);
jxlExcelWriter.setExcelTemplate("testRead");
List<String[]> accounts = new ArrayList<String[]>();
//省略测试数据生成...根据不同需要生成不同类型的数据
jxlExcelWriter.writeArrays(accounts);
//jxlExcelWriter.writeBeans(accounts);
//jxlExcelWriter.writeMaps(accounts);

生成excel模板

File tmp = new File("testWriteTemplate.xls");
if (tmp.exists()) {
tmp.delete();
}
tmp.createNewFile();
JxlExcelWriter jxlExcelWriter = new JxlExcelWriter(tmp);
jxlExcelWriter.setExcelTemplate("testRead");
jxlExcelWriter.writeTemplate();
  •        JXL操作excel的对象主要是:Workbook、Sheet、Cell。Workbook对应的就是一个excel,一个workbook可以有多个sheet对象,一个Sheet中有多个Cell。        读取excel的步骤概括为:        1. 上传excel文件,得到workbook        2. 选择workbook中的工作表sheet        3. 选

  • 1、Java编程中Excel常用格式汇总       第一行标题的格式定义         WritableWorkbook workbook = Workbook.createWorkbook(file); WritableSheet sheet = workbook.createSheet("报表统计", 0); //单元格 Writ

  • java 中JXL操作Excel实例详解 发布于 2021-1-2| 复制链接 摘记: JXL操作Excel 前言:jxl是一个韩国人写的java操作excel的工具, 在开源世界中,有两套比较有影响的API可 供使用,一个是POI,一个是jExcelAPI。其中功能相对POI比较弱一点。但jExcelAPI对中文支持非常好,API是纯 .. JXL操作Excel前言:jxl是一个韩国人写的jav

  • 最近项目要一个批量导出功能,而且要生成一个单独的sheet页,最后后面所有sheet的索引,并且可以点击进入连接。网上搜索了一下,找到一个方法,同时把相关的excel导入导出操作记录一下!以便以后使用! 简单先写一下目录的建立的主要代码,测试用的 List ls = new ArrayList();//报表名称列表 ls.add("BB_BB03"); ls.add("BB_BB05"); ls.

  •  一、创建文件  拟生成一个名为“test.xls”的Excel文件,其中第一个工作表被命名为 “第一页”,大致效果如下: ? 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 package test;    // 生成Excel的

  • 原文链接:Java实现Excel操作(JxlExcel导出导入) JxlExcel数据导出实现方法,及注解。 在实现功能时,需要导入对应的jar包,maven对应pom依赖如下: ##<!–依赖包–> <dependency> <groupId>net.sourceforge.jexcelapi</groupId> <artifactId>jxl</artifactId>

 相关资料
  • 本文向大家介绍读写问题,包括了读写问题的使用技巧和注意事项,需要的朋友参考一下 读写程序问题与多个进程之间共享的对象(例如文件)有关。这些过程中的一些是读取器,即他们只想从对象中读取数据,而某些过程是写入器,即他们想写到对象中。 读者-作家问题用于管理同步,因此对象数据没有问题。例如-如果两个读取器同时访问对象,则没有问题。但是,如果两位作者或一位读者和一位作家同时访问该对象,则可能会出现问题。

  • 我开始使用Scala,在从play framework页面上做一些示例时,我发现了我无法解决的问题。我是Scala的新手,所以请原谅我。 为什么这个编译没有错误: 重载的方法值读取的选项:[error](t:Double)play.api.libs.json.reads[Double][error](隐式r:play.api.libs.json.reads[Double])play.api.lib

  • 从1.r.58开始, 内置读写分离支持 ioc js形式的配置 NutDaoRunner新增了slaveDataSource属性 dataSource : { // master数据源 }, slaveDataSource : { // slave数据源,负责读 }, dao : { type : "org.

  • 9.3. sync.RWMutex读写锁 在100刀的存款消失时不做记录多少还是会让我们有一些恐慌,Bob写了一个程序,每秒运行几百次来检查他的银行余额。他会在家,在工作中,甚至会在他的手机上来运行这个程序。银行注意到这些陡增的流量使得存款和取款有了延时,因为所有的余额查询请求是顺序执行的,这样会互斥地获得锁,并且会暂时阻止其它的goroutine运行。 由于Balance函数只需要读取变量的状态

  • 在ReplicaSet副本集环境中,可以通过bugu-mongo设置读写分离。 默认情况下,写操作、读操作,全部都是在Primary上进行,如下图,这可能会导致Primary的负载比较高。 为了降低Primary的负载,可以设置成允许从Secondary读取数据,如下图: 慎重考虑 读写分离,看上去很美,但实际有如下问题需要考虑: 一般情况下,并不建议对ReplicaSet进行读写分离。因为,对于

  • ReplicaLoadBalanceAlgorithm SPI 名称 详细说明 ReplicaLoadBalanceAlgorithm 读库负载均衡算法 已知实现类 详细说明 RoundRobinReplicaLoadBalanceAlgorithm 基于轮询的读库负载均衡算法 RandomReplicaLoadBalanceAlgorithm 基于随机的读库负载均衡算法

  • 配置项说明 命名空间:http://shardingsphere.apache.org/schema/shardingsphere/readwrite-splitting/readwrite-splitting-5.0.0.xsd <readwrite-splitting:rule /> 名称 类型 说明 id 属性 Spring Bean Id data-source-rule (+) 标签 读

  • 配置项说明 spring.shardingsphere.datasource.names= # 省略数据源配置,请参考使用手册 spring.shardingsphere.rules.readwrite-splitting.data-sources.<readwrite-splitting-data-source-name>.write-data-source-name= # 写数据源名称 sp