第三方库,附件
缺点:该库只支持.xls文件的操作


1、读取excel文件


例子:
  1. try {
  2. /**
  3. * 后续考虑问题,比如Excel里面的图片以及其他数据类型的读取
  4. **/
  5. InputStream is = new FileInputStream(path);
  6. Workbook book = Workbook.getWorkbook(is);
  7. int num = book.getNumberOfSheets();
  8. publishProgress("the num of sheets is " + num+ "\n");
  9. if (num <2) {
  10. return -2;
  11. }
  12. // 获得第一个工作表对象:时间,电流值
  13. Sheet sheet = book.getSheet(0);
  14. int Rows = sheet.getRows();
  15. int Cols = sheet.getColumns();
  16. publishProgress("the name of sheet 1 is " + sheet.getName() + "\n");
  17. publishProgress("total rows is " + Rows + "\n");
  18. publishProgress("total cols is " + Cols + "\n");
  19. if (Cols != 2) {
  20. publishProgress("第一个工作表格式错误,第一列为时间(13位时间戳),第二列为电流值,导入停止");
  21. return -2;
  22. }
  23. for (int i = 0; i < Rows; i++) {
  24. String str1 = sheet.getCell(0,i).getContents();
  25. if (str1 == null || str1.isEmpty() || str1.length()!=13) {
  26. continue;
  27. }
  28. long longStr1 = -1L;
  29. try {
  30. longStr1 = Long.parseLong(str1);
  31. } catch (Exception e) {
  32. }
  33. String str2 = sheet.getCell(1,i).getContents();
  34. if (str2 == null || str2.isEmpty()) {
  35. continue;
  36. }
  37. float floatStr2 = -2F;
  38. try {
  39. floatStr2 = Float.parseFloat(str2);
  40. } catch (Exception e) {
  41. }
  42. if (longStr1 == -1 || floatStr2 == -2F) {
  43. continue;
  44. }
  45. publishProgress("contents:" + longStr1+","+ floatStr2 + "\n");
  46. //插入血糖
  47. GlucoseData vData = new GlucoseData();
  48. vData.setGlucoseElecValue(floatStr2);
  49. vData.setGlucoseTime(new Date(longStr1));
  50. vData.setGlucoseValue(-1F);
  51. vDataDao.insert(vData);
  52. }
  53. // 获得第二个工作表对象:时间,血糖值
  54. sheet = book.getSheet(1);
  55. Rows = sheet.getRows();
  56. Cols = sheet.getColumns();
  57. publishProgress("the name of sheet 2 is " + sheet.getName() + "\n");
  58. publishProgress("total rows is " + Rows + "\n");
  59. publishProgress("total cols is " + Cols + "\n");
  60. if (Cols != 2) {
  61. publishProgress("第二个工作表格式错误,第一列为时间(13位时间戳),第二列为参比血糖值,导入停止");
  62. return -2;
  63. }
  64. for (int i = 0; i < Rows; i++) {
  65. String str1 = sheet.getCell(0,i).getContents();
  66. if (str1 == null || str1.isEmpty() || str1.length()!=13) {
  67. continue;
  68. }
  69. long longStr1 = -1L;
  70. try {
  71. longStr1 = Long.parseLong(str1);
  72. } catch (Exception e) {
  73. }
  74. String str2 = sheet.getCell(1,i).getContents();
  75. if (str2 == null || str2.isEmpty()) {
  76. continue;
  77. }
  78. float floatStr2 = -2F;
  79. try {
  80. floatStr2 = Float.parseFloat(str2);
  81. } catch (Exception e) {
  82. }
  83. if (longStr1 == -1 || floatStr2 == -2F) {
  84. continue;
  85. }
  86. publishProgress("contents:" + longStr1+","+ floatStr2 + "\n");
  87. //插入血糖
  88. GlucoseRefData vData = new GlucoseRefData();
  89. vData.setGlucoseRefValue(floatStr2);
  90. vData.setGlucoseRefTime(new Date(longStr1));
  91. vGlucoseRefData.insert(vData);
  92. }
  93. book.close();
  94. publishProgress("完成数据导入\n");
  95. return 0;
  96. } catch (Exception e) {
  97. publishProgress(e.toString());
  98. return -1;
  99. }

2、生成Excel
  1. try {
  2. // 创建或打开Excel文件
  3. WritableWorkbook book = Workbook.createWorkbook(new File(mResultPath));
  4. // 生成名为“第一页”的工作表,参数0表示这是第一页
  5. WritableSheet sheet1 = book.createSheet("result", 0);
  6. List<GlucoseData> vList = vDataDao.loadAll();
  7. if (vList!=null) {
  8. for (int i = 0; i < vList.size(); i++) {
  9. jxl.write.Number number2 = new jxl.write.Number(0, i,vList.get(i).getGlucoseTime().getTime());
  10. sheet1.addCell(number2);
  11. jxl.write.Number number3 = new jxl.write.Number(1, i,vList.get(i).getGlucoseElecValue());
  12. sheet1.addCell(number3);
  13. jxl.write.Number number = new jxl.write.Number(2, i,vList.get(i).getGlucoseValue());
  14. sheet1.addCell(number);
  15. }
  16. }
  17. // 写入数据并关闭文件
  18. book.write();
  19. book.close();
  20. } catch (Exception e) {
  21. Log.d("algorithm", "WritableWorkbook exception: "+e.toString());
  22. publishProgress("WritableWorkbook exception: "+e.toString());
  23. return -3;
  24. }

附件列表

读取并创建excel文件(.xls)的更多相关文章

  1. 【转】Python xlrd、xlwt、xlutils读取、修改Excel文件

    Python xlrd.xlwt.xlutils读取.修改Excel文件 一.xlrd读取excel 这里介绍一个不错的包xlrs,可以工作在任何平台.这也就意味着你可以在Linux下读取Excel文 ...

  2. Java Struts2 POI创建Excel文件并实现文件下载

    Java Struts2 POI创建Excel文件并实现文件下载2013-09-04 18:53 6059人阅读 评论(1) 收藏 举报 分类: Java EE(49) Struts(6) 版权声明: ...

  3. Java中使用POI读取大的Excel文件或者输入流时发生out of memory异常参考解决方案

    注意:此参考解决方案只是针对xlsx格式的excel文件! 背景 前一段时间遇到一种情况,服务器经常宕机,而且没有规律性,查看GC日志发生了out of memory,是堆溢出导致的,分析了一下堆的d ...

  4. Jxl创建Excel文件和解析Excel文件

    import java.io.File; import jxl.Workbook; import jxl.write.Label; import jxl.write.WritableSheet; im ...

  5. NPOI 2.0 创建Excel文件

    如果只是简单的处理的话,只需要引用下载压缩包里的 NPOI.dll (office 2003)或 NPOI.OOXML.dll (office 2007) 文件而已. using System; us ...

  6. C#创建Excel文件并将数据导出到Excel文件

    工具原料: Windows 7,Visual Studio 2010, Microsoft Office 2007 创建解决方案 菜单>新建>项目>Windows窗体应用程序: 添加 ...

  7. c++ 读取并解析excel文件方法

    用Cocos开发模型特效工具编辑器,跨Mac和windows,当中有个需求是读取并解析excel文件,但网上的查找的例子几乎都只能是在windows下面使用,再或者是命令行脚本之类的.于是,自己写了一 ...

  8. C# 读取CSV和EXCEL文件示例

    我们习惯了直接连到数据库上面读取数据表的数据内容: 如果有一天我们需要读取CSV,EXCEL文件的内容的时候,可不可以也像读数据表的方式一样呢?当然可以,使用OleDB ADO.NET是很简单的事情 ...

  9. java读取excel文件(.xls,xlsx,csv)

    前提,maven工程通过poi读写excel文件,需要在pom.xml中配置依赖关系: 在<dependencies>中添加如下代码 <dependency> <grou ...

随机推荐

  1. php数据库常用函数

    //打开mysqlmysql_connect( $host, $user, $pwd ) or die('error');$host => localhost //数据库地址$user => ...

  2. Docker Hub仓库注册,使用

    首先保证可以访问Docker Hub,所以需要先把host替换一下 : Google hosts ; 然后就是注册Docker Hub账户:https://hub.docker.com/; 然后就是在 ...

  3. ArcServer 10.0 “No Content”、“Server Host Cannot be null” 错误

    问题一:"No Content" 问题描述: 在输入服务地址时:http://192.168.1.180/arcgis/services   结果出现下面的错误:   解决办法: ...

  4. SVN中Branch的创建与合并

    在使用源代码版本控制工具时,最佳实践是一直保持一个主干版本.但是为了应付实际开发中的各种情况,适时的开辟一些分支也是很有必要的.比如在持续开发新功能的同时,需要发布一个新版本,那么就需要从开发主干中建 ...

  5. [BTS] Action demo In BizTalk WCF-SAP Adapter

    I use following xml config in BizTalk 2010 WCF-SAP adapter. <BtsActionMapping xmlns:xsi="htt ...

  6. C++ Primer 快速入门

    <C++ Primer 4th> 读书摘要 必须有一个命名为 main.操作系统通过 main 函数返回的值来确定程序是否成功执行完毕.返回 0 值表明程序程序成功执行完毕.任何其他非零的 ...

  7. Spring AOP(注解方式)

    配置文件: xmlns:aop="http://www.springframework.org/schema/aop" http://www.springframework.org ...

  8. 工作圈redis 使用

    redis作为内存数据库,更多的是作为内存cache来使用. 再所负责的工作圈中的使用,主要是分两方面: 1.数据对象: 主题的内容存储 主题回复内容的存储 用户信息存储 圈子信息存储 2.各数据对象 ...

  9. paip.一千 常用汉字 高频汉字 覆盖率90%

    paip.一千 常用汉字 高频汉字 覆盖率90%  一千个使用频率最高的汉字,其覆盖率达一般书刊用字的90%. 作者Attilax  艾龙,  EMAIL:1466519819@qq.com 来源:a ...

  10. javaweb学习总结(二十五)——jsp简单标签开发(一)

    一.简单标签(SimpleTag) 由于传统标签使用三个标签接口来完成不同的功能,显得过于繁琐,不利于标签技术的推广, SUN公司为降低标签技术的学习难度,在JSP 2.0中定义了一个更为简单.便于编 ...