读取并创建excel文件(.xls)
1、读取excel文件
try {
/**
* 后续考虑问题,比如Excel里面的图片以及其他数据类型的读取
**/
InputStream is = new FileInputStream(path);
Workbook book = Workbook.getWorkbook(is);
int num = book.getNumberOfSheets();
publishProgress("the num of sheets is " + num+ "\n");
if (num <2) {
return -2;
}
// 获得第一个工作表对象:时间,电流值
Sheet sheet = book.getSheet(0);
int Rows = sheet.getRows();
int Cols = sheet.getColumns();
publishProgress("the name of sheet 1 is " + sheet.getName() + "\n");
publishProgress("total rows is " + Rows + "\n");
publishProgress("total cols is " + Cols + "\n");
if (Cols != 2) {
publishProgress("第一个工作表格式错误,第一列为时间(13位时间戳),第二列为电流值,导入停止");
return -2;
}
for (int i = 0; i < Rows; i++) {
String str1 = sheet.getCell(0,i).getContents();
if (str1 == null || str1.isEmpty() || str1.length()!=13) {
continue;
}
long longStr1 = -1L;
try {
longStr1 = Long.parseLong(str1);
} catch (Exception e) {
}
String str2 = sheet.getCell(1,i).getContents();
if (str2 == null || str2.isEmpty()) {
continue;
}
float floatStr2 = -2F;
try {
floatStr2 = Float.parseFloat(str2);
} catch (Exception e) {
}
if (longStr1 == -1 || floatStr2 == -2F) {
continue;
}
publishProgress("contents:" + longStr1+","+ floatStr2 + "\n");
//插入血糖
GlucoseData vData = new GlucoseData();
vData.setGlucoseElecValue(floatStr2);
vData.setGlucoseTime(new Date(longStr1));
vData.setGlucoseValue(-1F);
vDataDao.insert(vData);
}
// 获得第二个工作表对象:时间,血糖值
sheet = book.getSheet(1);
Rows = sheet.getRows();
Cols = sheet.getColumns();
publishProgress("the name of sheet 2 is " + sheet.getName() + "\n");
publishProgress("total rows is " + Rows + "\n");
publishProgress("total cols is " + Cols + "\n");
if (Cols != 2) {
publishProgress("第二个工作表格式错误,第一列为时间(13位时间戳),第二列为参比血糖值,导入停止");
return -2;
}
for (int i = 0; i < Rows; i++) {
String str1 = sheet.getCell(0,i).getContents();
if (str1 == null || str1.isEmpty() || str1.length()!=13) {
continue;
}
long longStr1 = -1L;
try {
longStr1 = Long.parseLong(str1);
} catch (Exception e) {
}
String str2 = sheet.getCell(1,i).getContents();
if (str2 == null || str2.isEmpty()) {
continue;
}
float floatStr2 = -2F;
try {
floatStr2 = Float.parseFloat(str2);
} catch (Exception e) {
}
if (longStr1 == -1 || floatStr2 == -2F) {
continue;
}
publishProgress("contents:" + longStr1+","+ floatStr2 + "\n");
//插入血糖
GlucoseRefData vData = new GlucoseRefData();
vData.setGlucoseRefValue(floatStr2);
vData.setGlucoseRefTime(new Date(longStr1));
vGlucoseRefData.insert(vData);
}
book.close();
publishProgress("完成数据导入\n");
return 0;
} catch (Exception e) {
publishProgress(e.toString());
return -1;
}
try {
// 创建或打开Excel文件
WritableWorkbook book = Workbook.createWorkbook(new File(mResultPath));
// 生成名为“第一页”的工作表,参数0表示这是第一页
WritableSheet sheet1 = book.createSheet("result", 0);
List<GlucoseData> vList = vDataDao.loadAll();
if (vList!=null) {
for (int i = 0; i < vList.size(); i++) {
jxl.write.Number number2 = new jxl.write.Number(0, i,vList.get(i).getGlucoseTime().getTime());
sheet1.addCell(number2);
jxl.write.Number number3 = new jxl.write.Number(1, i,vList.get(i).getGlucoseElecValue());
sheet1.addCell(number3);
jxl.write.Number number = new jxl.write.Number(2, i,vList.get(i).getGlucoseValue());
sheet1.addCell(number);
}
}
// 写入数据并关闭文件
book.write();
book.close();
} catch (Exception e) {
Log.d("algorithm", "WritableWorkbook exception: "+e.toString());
publishProgress("WritableWorkbook exception: "+e.toString());
return -3;
}
附件列表
读取并创建excel文件(.xls)的更多相关文章
- 【转】Python xlrd、xlwt、xlutils读取、修改Excel文件
Python xlrd.xlwt.xlutils读取.修改Excel文件 一.xlrd读取excel 这里介绍一个不错的包xlrs,可以工作在任何平台.这也就意味着你可以在Linux下读取Excel文 ...
- Java Struts2 POI创建Excel文件并实现文件下载
Java Struts2 POI创建Excel文件并实现文件下载2013-09-04 18:53 6059人阅读 评论(1) 收藏 举报 分类: Java EE(49) Struts(6) 版权声明: ...
- Java中使用POI读取大的Excel文件或者输入流时发生out of memory异常参考解决方案
注意:此参考解决方案只是针对xlsx格式的excel文件! 背景 前一段时间遇到一种情况,服务器经常宕机,而且没有规律性,查看GC日志发生了out of memory,是堆溢出导致的,分析了一下堆的d ...
- Jxl创建Excel文件和解析Excel文件
import java.io.File; import jxl.Workbook; import jxl.write.Label; import jxl.write.WritableSheet; im ...
- NPOI 2.0 创建Excel文件
如果只是简单的处理的话,只需要引用下载压缩包里的 NPOI.dll (office 2003)或 NPOI.OOXML.dll (office 2007) 文件而已. using System; us ...
- C#创建Excel文件并将数据导出到Excel文件
工具原料: Windows 7,Visual Studio 2010, Microsoft Office 2007 创建解决方案 菜单>新建>项目>Windows窗体应用程序: 添加 ...
- c++ 读取并解析excel文件方法
用Cocos开发模型特效工具编辑器,跨Mac和windows,当中有个需求是读取并解析excel文件,但网上的查找的例子几乎都只能是在windows下面使用,再或者是命令行脚本之类的.于是,自己写了一 ...
- C# 读取CSV和EXCEL文件示例
我们习惯了直接连到数据库上面读取数据表的数据内容: 如果有一天我们需要读取CSV,EXCEL文件的内容的时候,可不可以也像读数据表的方式一样呢?当然可以,使用OleDB ADO.NET是很简单的事情 ...
- java读取excel文件(.xls,xlsx,csv)
前提,maven工程通过poi读写excel文件,需要在pom.xml中配置依赖关系: 在<dependencies>中添加如下代码 <dependency> <grou ...
随机推荐
- [leetcode 23]Merge k Sorted Lists
1 题目 Merge k sorted linked lists and return it as one sorted list. Analyze and describe its complexi ...
- Lambda表达式的前世今生
Lambda 表达式 早在 C# 1.0 时,C#中就引入了委托(delegate)类型的概念.通过使用这个类型,我们可以将函数作为参数进行传递.在某种意义上,委托可理解为一种托管的强类型的函数指针. ...
- NABC模型进行需求分析
N(需求): 图书租售管理系统.图书租售管理系统必须包含有完善的图书出租功能.还租.预订(租).会员管理.积分管理.简单的财务系统.详细分类统计.各数据排行榜.详细权限管理. A(做法): 因为有一些 ...
- 冲刺阶段 day2
day2 项目进展 今天本组五位同学聚在一起将项目启动,首先我们对项目进行了规划,分工,明确指出每个人负责哪些项目.由负责第一部分的组员开始编程,在已经搭建好的窗体内,对系部设置进行了编写,本校共六个 ...
- 从快的线上callback hell代码说起
概述 就像谈到闭包必须要说js变量作用域一样,谈到 promise 之前肯定要先说谈异步编程.一直以来, javascript 处理异步方式都是使用 callback 方式,对与写 javascrip ...
- python os&shutil 文件操作
python os&shutil 文件操作 # os 模块 os.sep 可以取代操作系统特定的路径分隔符.windows下为 '\\' os.name 字符串指示你正在使用的平台.比如对于W ...
- HTML5 Canvas实现黑客帝国文字掉落效果
效果: 原理: 用canvas逐行输出文字,然后让背景颜色逐渐加深,再随机中断某些列. 代码: HTML: <canvas id="c"></canvas> ...
- 使用paramikoHelper类实现MySQL安装和数据恢复
本脚本实现远程Linux主机登陆和安装MySQL的rpm包,同时导入mysql数据,实现自动化安装 paramikoHelper类在本博客中 http://www.cnblogs.com/djoker ...
- 【UML】类图的几种关系总结
在UML类图中,常见的有以下几种关系:泛化(Generalization), 实现(Realization),关联(Association),聚合(Aggregation),组合(Compositi ...
- DL 小记之序
在开通博客的1小时03分钟50秒,我写下了第一篇文字.不知道从什么时候开始,什么东西都有个期限,在写下几小时几分几秒之后,我总是习惯性的加上不知道从什么时候开始. 本博客不含惊天动地的故事,想看故事请 ...