Android操作Excel文件的功能实现

Android中操作Excel文件导出报表时主要采用开源库jxl,最早用在java上,但也可用于Android。与之类似的POI,因为依赖库众多,所以只能用于java,而不能用于Android。

使用jxl需要在Android工程中导入jxl.jar包,jxl可以完成Excel的基本读写操作,其支持与不支持的情况如下:

1、jxl只支持Excel2003格式,不支持Excel2007格式。即支持xls文件,不支持xlsx文件。

2、jxl不支持直接修改excel文件,但可通过复制新文件覆盖原文件的方式来间接修改。

3、jxl只能识别PNG格式的图片,不能识别其他格式的图片。

上面可以看出,jxl不支持Excel2007,这个很不好,尤其是目前Excel2007已经成为Excel主流格式的时候。不过现在还有个实现Android读取2007格式的临时办法,如果我们仔细分析xlsx的文件格式,会发现xlsx文件其实是个压缩包,压缩包里有各种文件,其中数据一般是放在"xl/sharedStrings.xml"和"xl/worksheets/sheet1.xml"中。据此,我们判断Excel文件为2007格式时,便可以将其解压,然后从中提取出sharedStrings.xml和sheet1.xml,接着使用XML解析工具把具体数据解析出来。

下面是Excel文件的读写代码例子,其中支持2003格式的读和写,以及2007格式的读:

import java.io.File; 

import java.io.IOException; 

import java.io.InputStream; 

import java.util.ArrayList; 

import java.util.List; 

import java.util.zip.ZipEntry; 

import java.util.zip.ZipException; 

import java.util.zip.ZipFile; 

import org.xmlpull.v1.XmlPullParser; 

import org.xmlpull.v1.XmlPullParserException; 

import android.util.Log; 

import android.util.Xml; 

import jxl.Sheet; 

import jxl.Workbook; 

import jxl.write.Label; 

import jxl.write.WritableSheet; 

import jxl.write.WritableWorkbook; 

public class ExcelUtil { 

 private final static String TAG = "ExcelUtil";
 public static List<List<Object>> read(String file_name) { 

  String extension = file_name.lastIndexOf(".") == -1 ? "" : file_name 

    .substring(file_name.lastIndexOf(".") + 1); 

  if ("xls".equals(extension)) {// 2003 

   Log.d(TAG, "read2003XLS, extension:" + extension); 

   return read2003XLS(file_name); 

  } else if ("xlsx".equals(extension)) { 

   Log.d(TAG, "read2007XLSX, extension:" + extension); 

   return read2007XLSX(file_name); 

  } else { 

   Log.d(TAG, "不支持的文件类型, extension:" + extension); 

   return null; 

  }
 }
 public static List<List<Object>> read2003XLS(String path) { 

  List<List<Object>> dataList = new ArrayList<List<Object>>(); 

  try { 

   Workbook book = Workbook.getWorkbook(new File(path)); 

   // book.getNumberOfSheets(); //获取sheet页的数目 

   // 获得第一个工作表对象 

   Sheet sheet = book.getSheet(0); 

   int Rows = sheet.getRows(); 

   int Cols = sheet.getColumns(); 

   Log.d(TAG, "当前工作表的名字:" + sheet.getName()); 

   Log.d(TAG, "总行数:" + Rows + ", 总列数:" + Cols);
   List<Object> objList = new ArrayList<Object>(); 

   String val = null; 

   for (int i = 0; i < Rows; i++) { 

    boolean null_row = true; 

    for (int j = 0; j < Cols; j++) { 

     // getCell(Col,Row)获得单元格的值,注意getCell格式是先列后行,不是常见的先行后列 

     Log.d(TAG, (sheet.getCell(j, i)).getContents() + "\t"); 

     val = (sheet.getCell(j, i)).getContents(); 

     if (val == null || val.equals("")) { 

      val = "null"; 

     } else { 

      null_row = false; 

     } 

     objList.add(val); 

    } 

    Log.d(TAG, "\n"); 

    if (null_row != true) { 

     dataList.add(objList); 

     null_row = true; 

    } 

    objList = new ArrayList<Object>(); 

   } 

   book.close(); 

  } catch (Exception e) { 

   Log.d(TAG, e.getMessage()); 

  }
  return dataList; 

 }
 public static List<List<Object>> read2007XLSX(String path) { 

  List<List<Object>> dataList = new ArrayList<List<Object>>(); 

  String str_c = ""; 

  String v = null; 

  boolean flat = false; 

  List<String> ls = new ArrayList<String>(); 

  try { 

   ZipFile xlsxFile = new ZipFile(new File(path)); 

   ZipEntry sharedStringXML = xlsxFile.getEntry("xl/sharedStrings.xml"); 

   if (sharedStringXML == null) { 

    Log.d(TAG, "空文件:" + path); 

    return dataList; 

   } 

   InputStream inputStream = xlsxFile.getInputStream(sharedStringXML); 

   XmlPullParser xmlParser = Xml.newPullParser(); 

   xmlParser.setInput(inputStream, "utf-8");
   int evtType = xmlParser.getEventType(); 

   while (evtType != XmlPullParser.END_DOCUMENT) { 

    switch (evtType) { 

    case XmlPullParser.START_TAG: 

     String tag = xmlParser.getName(); 

     if (tag.equalsIgnoreCase("t")) { 

      ls.add(xmlParser.nextText()); 

     } 

     break; 

    case XmlPullParser.END_TAG: 

     break; 

    default: 

     break; 

    } 

    evtType = xmlParser.next(); 

   } 

   ZipEntry sheetXML = xlsxFile.getEntry("xl/worksheets/sheet1.xml"); 

   InputStream inputStreamsheet = xlsxFile.getInputStream(sheetXML); 

   XmlPullParser xmlParsersheet = Xml.newPullParser(); 

   xmlParsersheet.setInput(inputStreamsheet, "utf-8");
   int evtTypesheet = xmlParsersheet.getEventType(); 

   List<Object> objList = new ArrayList<Object>(); 

   String val = null;
   boolean null_row = true;
    while (evtTypesheet != XmlPullParser.END_DOCUMENT) { 

    switch (evtTypesheet) { 

    case XmlPullParser.START_TAG: 

     String tag = xmlParsersheet.getName(); 

     if (tag.equalsIgnoreCase("row")) { 

     } else if (tag.equalsIgnoreCase("c")) {
      String t = xmlParsersheet.getAttributeValue(null, "t"); 

      if (t != null) { 

       flat = true; // 字符串型 

       // Log.d(TAG, flat + "有"); 

      } else { // 非字符串型,可能是整型 

       // Log.d(TAG, flat + "没有"); 

       flat = false; 

      } 

     } else if (tag.equalsIgnoreCase("v")) { 

      v = xmlParsersheet.nextText(); 

      if (v != null) { 

       if (flat) { 

        str_c += ls.get(Integer.parseInt(v)) + " "; 

        val = ls.get(Integer.parseInt(v)); 

        null_row = false; 

       } else { 

        str_c += v + " "; 

        val = v; 

       } 

       objList.add(val); 

      } 

     } 

     break; 

    case XmlPullParser.END_TAG: 

     if (xmlParsersheet.getName().equalsIgnoreCase("row") && v != null) { 

      str_c += "\n"; 

      if (null_row != true) { 

       dataList.add(objList); 

       null_row = true; 

      }
      objList = new ArrayList<Object>(); 

     }
     break;
    }
    evtTypesheet = xmlParsersheet.next(); 

   }
   Log.d(TAG, str_c); 

  } catch (ZipException e) { 

   e.printStackTrace(); 

  } catch (IOException e) { 

   e.printStackTrace(); 

  } catch (XmlPullParserException e) { 

   e.printStackTrace(); 

  }
  if (str_c == null) { 

   str_c = "解析文件出现问题"; 

   Log.d(TAG, str_c); 

  }
  return dataList; 

 }
 public static int writeExcel(String file_name, List<List<Object>> data_list) { 

  try { 

   WritableWorkbook book = Workbook.createWorkbook(new File(file_name)); 

   WritableSheet sheet1 = book.createSheet("sheet1", 0); 

   for (int i = 0; i < data_list.size(); i++) { 

    List<Object> obj_list = data_list.get(i); 

    for (int j = 0; j < obj_list.size(); j++) { 

     Label label = new Label(j, i, obj_list.get(j).toString()); 

     sheet1.addCell(label);
    }
   }
   book.write();
   book.close(); 

  } catch (Exception e) { 

   e.printStackTrace();
   return -1;
  }
  return 0;
 } 

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持我们。

(0)

相关推荐

  • Android 中读取Excel文件实例详解

    Android 中读取Excel文件实例详解 最近有个需求需要在app内置数据,新来的产品扔给了我两个Excel表格就不管了(两个表格格式还不统一...),于是通过度娘等方法找到了Android中读取Excel表格文件的一种方法,记录一下. 闲话一下Excel中工作簿和工作表的区别: 工作簿中包含有工作表.工作簿可以由一张或多张工作表组成,一个工作簿就是一个EXCEL表格文件. 好了,开始读取表格文件吧. 前提 首先,我们假设需要读取的表格文件名字为test.xls, 位于assets根目录下.

  • Android应用读取Excel文件的方法

    本文实例讲述了Android应用读取Excel文件的方法.分享给大家供大家参考,具体如下: ReadExcel.java文件: public class ReadExcel extends Activity { /** Called when the activity is first created. */ @Override public void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState)

  • Android中使用sax解析xml文件的方法

    SAX是一个解析速度快并且占用内存少的xml解析器,非常适合用于Android等移动设备. SAX解析XML文件采用的是事件驱动,也就是说,它并不需要解析完整个文档,在按内容顺序解析文档的过程中,SAX会判断当前读到的字符是否合法XML 语法中的某部分,如果符合就会触发事件.所谓事件,其实就是一些回调(callback)方法,这些方法(事件)定义在ContentHandler接口.下面是一些ContentHandler接口常用的方法: startDocument():当遇到文档的开头的时候,调用

  • android通过jxl读excel存入sqlite3数据库

    复制代码 代码如下: package com.demo.day20140228; import java.io.File;import java.sql.Connection;import java.sql.DriverManager;import java.sql.PreparedStatement;import java.sql.SQLException;import java.sql.Statement; import jxl.Cell;import jxl.Sheet;import jx

  • 基于Android XML解析与保存的实现

    解析XML文件:在Android平台上可以使用SAX.DOM和Android附带的pull解析器解析XML文件:pull解析器提供了各种事件,使用parser.next()方法进入下一个元素并触发相应事件,pull解析器产生的事件是一个数字,可以通过switch对感兴趣的事件进行处理:通过paser.nextText()方法可以获取下一个Text类型的节点的值:http://xmlpull.org/xmlpull-website/impls.shtml; 读取XMLXmlPullParser p

  • android操作XML的几种方法总结

    XML作为一种业界公认的数据交换格式,在各个平台与语言之上,都有广泛使用和实现.其标准型,可靠性,安全性......毋庸置疑.在android平台上,我们要想实现数据存储和数据交换,经常会使用到xml数据格式和xml文件. 小提示:android中存储数据一般有如下几种:SharedPreferences(参数化),XML文件,sqllite数据库,网络,ContentProvider(内容提供者)等. 在android中,操作xml文件,一般有几种方式:SAX操作,Pull操作,DOM操作等.

  • Android开发实现读取excel数据并保存为xml的方法

    本文实例讲述了Android开发实现读取excel数据并保存为xml的方法.分享给大家供大家参考,具体如下: 前阵子,公司请外面人翻译了一些android中values中的一些strings,然而保存的都是excel格式,如果单纯的将excel中的数据粘贴到指定的xml中的话,工作量非常的大,于是,自己写了个简单的demo,将excel中的数据读取并保存为xml对应的数据,下面的demo和图片展示: 1.数据保存在BeanValue中,包括key和value,方便后续数据读取 package c

  • android编程之xml文件读取和写入方法

    本文实例讲述了android编程之xml文件读取和写入方法.分享给大家供大家参考.具体分析如下: 一.环境: 主机:WIN8 开发环境:Eclipse 二.说明: 1.打开sd卡中的xml文件,如果不存在,这新建一个,并写入默认配置 2.读取xml文件 三.xml文件格式: <?xml version="1.0" encoding="UTF-8" standalone="true"?> -<config> <titl

  • Android操作Excel文件的功能实现

    Android中操作Excel文件导出报表时主要采用开源库jxl,最早用在java上,但也可用于Android.与之类似的POI,因为依赖库众多,所以只能用于java,而不能用于Android. 使用jxl需要在Android工程中导入jxl.jar包,jxl可以完成Excel的基本读写操作,其支持与不支持的情况如下: 1.jxl只支持Excel2003格式,不支持Excel2007格式.即支持xls文件,不支持xlsx文件. 2.jxl不支持直接修改excel文件,但可通过复制新文件覆盖原文件

  • Android 操作excel功能实例代码

    学习app对excel的读写控制 1.界面设计 <?xml version="1.0" encoding="utf-8"?> <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:tools="http://schemas.android.com/tools" android:id="@+id

  • Android编程实现文件浏览功能的方法【类似于FileDialog的功能】

    本文实例讲述了Android编程实现文件浏览功能的方法.分享给大家供大家参考,具体如下: 最近正在弄上传文件,当时想怎么能实现fileDialog的功能呢,打开文件,浏览文件,然后选择文件呢,查了好多资料,也看了不少论坛,都说里面没有这个功能,那真是奇怪了,里面没有这个功能,当然就需要自己动手添加这个功能了. 首先说一下这个文件浏览的简单实现原理: 首先选择一个目录做为根目录,然后打开此目录,常用的就是使用File这个类了,如下: File file=new File(path); 然后可以通过

  • java使用POI操作excel文件

    一.POI的定义 JAVA中操作Excel的有两种比较主流的工具包: JXL 和 POI .jxl 只能操作Excel 95, 97, 2000也即以.xls为后缀的excel.而poi可以操作Excel 95及以后的版本,即可操作后缀为 .xls 和 .xlsx两种格式的excel. POI全称 Poor Obfuscation Implementation,直译为"可怜的模糊实现",利用POI接口可以通过JAVA操作Microsoft office 套件工具的读写功能.官网:htt

  • 纯JS实现的读取excel文件内容功能示例【支持所有浏览器】

    本文实例讲述了纯JS实现的读取excel文件内容功能.分享给大家供大家参考,具体如下: template.html <html> <head> <meta http-equiv="Content-Type" content="text/html; charset=UTF-8"> <title>JS-XLSX Live Demo</title> <link href="../css/boots

  • Java操作Excel文件解析与读写方法详解

    目录 一.概述 二.Apache POI 三.XSSF解析Excel文件 1.Workbook(Excel文件) 2.Sheet(工作簿) 3.Row(数据行) 4.Cell(单元格) 四.超大Excel文件读写 1.使用POI写入 2.使用EasyExcel 一.概述 在应用程序的开发过程中,经常需要使用 Excel 文件来进行数据的导入或导出.所以,在通过Java语言实现此 类需求的时候,往往会面临着Excel文件的解析(导入)或生成(导出). 在Java技术生态圈中,可以进行Excel文件

  • JavaWeb使用POI操作Excel文件实例

    1.为项目添加POI POI官网链接 点进去之后下载(上边的是编译好的类,下边的是源代码) 解压文件夹,把下面三个文件复制到WebComtent>WEB-INF>lib文件夹下 再把这三个文件复制到Tomcat的lib文件夹下,否则Tomcat会因为找不到类而报错(这个地方郁闷了一上午) 读取".xls"格式使用  import org.apache.poi.hssf.usermodel.*;包的内容,例如:HSSFWorkbook 读取".xlsx"格

  • 使用Python操作excel文件的实例代码

    使用的类库 pip install openpyxl 操作实现 •工作簿操作 # coding: utf-8 from openpyxl import Workbook # 创建一个excel工作簿 wb = Workbook() # 打开一个工作簿 wb = load_workbook('test.xlsx') # 保存工作簿到文件 wb.save('save.xlsx') •工作表操作 # 获得当前的工作表对象 ws = wb.active # 通过工作表名称得到工作表对象 ws = wb.

  • C#使用oledb操作excel文件的方法

    本文实例讲述了C#使用oledb操作excel文件的方法.分享给大家供大家参考.具体分析如下: 不管什么编程语言都会提供操作Excel文件的方式,C#操作Excel主要有以下几种方式: 1.Excel 说明:利用Office 的Excel组件来操作excel文件 优点:能够完全操作Excel文件,生成丰富文件内容 缺点:需要电脑安装Excel,会启动Excel进程这在web上很不方便 2.OpenXML 说明:一个操作字处理文档的组件包括Excel 优点:能够操作操作Excel2007版本文件

  • python操作excel文件并输出txt文件的实例

    如下所示: #coding=utf-8 import os import xlrd #excel文件放置在当前路径 path='model.xls' #打开文件 data=xlrd.open_workbook(path) #查询工作表 sheets=data.sheets() #可以通过函数.索引.名称获得工作表. # sheet_1_by_function=data.sheets()[0] # sheet_1_by_index=data.sheet_by_index(0) sheet_1_by

随机推荐