Android 优雅的读写Excel
作者:Hujian 发布时间:2021-09-19 15:10:37
标签:Android,读写,Excel
Excel
apache 为 java开发者们提供了一套excel表格读写的工具:POI ,对于一个小白来说每次读写使用POI需要写一套复杂的读写流程实属不易,这里小编为大家封装了一套简单易用的excel读写工具
注解 | 描述 |
---|---|
@ExcelReadCell | Name 标记表头名称 |
@ExcelTable | 使用类上用来指定表名 |
@ExcelWriteAdapter | 展开数据集合适配器 |
@ExcelWriteCell | 输出文件编辑列名称,列号信息。 |
@ExcelReadAggregate | 标记类成员变量用来保存没有标记的数据 |
读取excel文件:
数据源(表名称:测试表1):
物品编码 | 物品名称 | 存放位置 | 备注 | 日期 |
---|---|---|---|---|
TY122635 | 厨房-面团分割机 | 0 | SDS-30S | 2021.2.1 |
TY122654 | 黑白激光打印机 | 0 | 兄弟 HL-5590DN | 2021.2.2 |
TY122652 | 黑白激光打印机 | 0 | 兄弟 HL-5590DN | 2021.2.3 |
TY122634 | 台式计算机 | 0 | 联想ThinkCentre M710t-D749 | 2021.2.4 |
创建实体对象:
@ExcelTable(sheetName = "测试表1")
public class Table {
@ExcelReadCell(name = "存放位置")
public String storageLocation;
@ExcelReadCell(name = "物品名称")
public String name;
@ExcelReadCell(name = "物品编码")
public String code;
//指定此变量保存其他数据,也可以不处理
@ExcelReadAggregate
public String extend;
}
这里只指定了三列数据,其他没有指定的数据列(备注、日期),将被聚合保存到被**@ExcelReadAggregate标注extend变量中,当然如果不需要这些数据也可以不用声明变量使用@ExcelReadAggregate**标注。
被@ExcelReadAggregate标注的对象接收的是一个JsonArray String 对象。
Table
{
storageLocation='0',
note='SDS-30S',
name='厨房-面团分割机',
code='TY2023122635',
extend=
'[{"name":"日期","value":"2021.2.1","index":7},{"name":"备注","value":"SDS30S","index":8}]'
Use:
Excel.get().readWith(is).doReadXLSX(new IParseListener<Table>() {
@Override
public void onStartParse() {
}
@Override
public void onParse(Table test, JSONArray jsonArray) {
}
@Override
public void onParseError(Exception e) {
}
@Override
public void onEndParse() {
}
}, Table.class);
输出excel文件:
@ExcelTable(sheetName = "测试表1")
public class Table {
@ExcelWriteCell(writeIndex = 2, writeName = "存放位置")
public String storageLocation;
@ExcelWriteCell(writeIndex = 1, writeName = "物品名称")
public String name;
@ExcelWriteCell(writeIndex = 0, writeName = "物品编码")
public String code;
//如果你将多个数据聚合在某一个变量中,可以通过实现IConvertParserAdapter接口来处理数据以便正确写入文件
@ExcelWriteAdapter(adapter = JsonArrayConvertAdapter.class)
public String extend;
}
@ExcelWriteCell
ExcelWriteCell注解有两个属性,writeIndex指定数据所属列,writeName指定列名称
@ExcelWriteAdapter
ExcelWriteAdapter用来辅助工具正确写入用户自定义的聚合数据。
这里extend 的数据如下:
[
{
"name":"日期",
"value":"2021.2.9",
"index":3
},
{
"name":"备注",
"value":"1.0",
"index":4
}
]
Name 表示列名称,value表示值,index表示列号,这里的数据结构可以自行定义。
IConvertParserAdapter 接口
使用了聚合数据,就需要实现IConvertParserAdapter接口用来解析你的聚合数据并通过ISheet接口回调数据的列名称,值,列号等信息。
针对上面的聚合数据:
public class JsonArrayConvertAdapter implements IConvertParserAdapter {
@Override
public void convert(ISheet sheet, Object o) {
JSONArray jsonArray = null;
try {
jsonArray = new JSONArray((String) o);
} catch (JSONException e) {
e.printStackTrace();
}
for (int i = 0; i < jsonArray.length(); i++) {
JSONObject json = (JSONObject) jsonArray.opt(i);
String name = (String) json.opt("name");
Object value = json.opt("value");
int index = (int) json.opt("index");
sheet.onCreateCell(name, value, index);
}
}
}
@ExcelWriteAdapter使用方法:
@ExcelWriteAdapter(adapter = JsonArrayConvertAdapter.class)
public String extend;
Use:
Excel.get().writeWith(file).doWrite(new IWriteListener() {
@Override
public void onStartWrite() {
Log.d(TAG, "onStartWrite: ");
}
@Override
public void onWriteError(Exception e) {
Log.d(TAG, "onWriteError: "+e);
}
@Override
public void onEndWrite() {
Log.d(TAG, "onEndWrite: ");
}
},data);
gitee地址:gitee.com/Jian-Hu/Exc…
github地址:github.com/Andihu/Exce…
来源:https://juejin.cn/post/7213771312121102394


猜你喜欢
- 前言本文将模块化地介绍如何实现一个动态开辟空间的通讯录,其有以下九个功能:打印主菜单添加联系人删除联系人打印通讯录查找联系人修改联系人置顶联
- 本文实例为大家分享了java顺时针打印矩阵的具体代码,供大家参考,具体内容如下github:剑指offer编程题 import j
- Java基础编写猜数游戏,供大家参考,具体内容如下设计内容及要求产生一个100以内的随机数,游戏者进行猜数,猜中即胜,猜不中,提示是大了还是
- 简介常见的4种使用线程的方法:1实现 Runnable 接口;2实现 Callable 接口;3继承 Thread 类。4匿名内部类的写法。
- Java 理解 ThreadLocal摘要: ThreadLocal 又名线程局部变量,是 Java 中一种较为特殊的线程绑定机制,用于保证
- 目前有两种流行Spring定时器配置:Java的Timer类和OpenSymphony的Quartz。1.Java Timer定时首先继承j
- 目录前言hibernate-validator基本使用引入依赖编写需要验证对象验证对象属性是否符合要求验证规则空/非空验证bool时间数学字
- springMVC默认的解析器里面是没有加入对文件上传的解析的,,使用springmvc对文件上传的解析器来处理文件上传的时需要用sprin
- 本文实例为大家分享了WPF ProgressBar实现实时进度的具体代码,供大家参考,具体内容如下简单测试,页面如图:利用上班的一点点空闲时
- JavaMail API中定义了一个java.mail.Transport类,它专门用于执行邮件发送任务,这个类的实例对象封装了某种邮件发送
- 简介在 io 包中,提供了两个与平台无关的数据操作流:数据输出流(DataOutputStream)、数据输入流 (DataInputStr
- 本文总结分析了Android编程开发之EditText中inputType属性。分享给大家供大家参考,具体如下:android 1.5以后添
- 本文研究的主要是Hibernate hql查询的相关内容,具体如下。HQL介绍Hibernate语言查询(Hibernate Query L
- 在2020.1.1版本之前IDEA pom文件导包是这样的最近新装新版本IDEA之后,这个图标没有了,对于习惯旧操作没有图标了还真不习惯。就
- 多亏了<include />标签,在Android里,很容易就能做到共享和重用UI组件。在Android开发中,很容易就能创建出
- 一般入参我们都会转为vo对象。那么直接在对象的属性上注解即可。 其实spring用的是hibernate的validator.步骤1.配置s
- 前言这篇文章探索一下springboot的tomcat是如何实现的一、起步依赖1.首先我们了解一下起步依赖SpringBoot结合Maven
- 一.总体设计1.寻找规律,公式化的生成坐标系。2.将生成坐标系的关键参数设置为可自定义,从而可变的可以生成自己想要的坐标系。3.将需要绘制的
- 经过几天的折腾,终于到了学习一个重量级的查询方式上,使用@Query注解,使用注解有两种方式,一种是JPQL的SQL语言方式,一种是原生SQ
- OverView今天在复习的时候,突然复习到我们的相机操作,但是对于相机操作,对于我来说比较复杂的是对于权限的操作。所有我们需要对我们的相机