android读取assets中Excel表格并显示

 更新时间:2017年02月04日 14:07:31   作者:ami_daqi  
这篇文章主要为大家详细介绍了android读取assets中Excel表格并显示的相关资料,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

本文实例为大家分享了android读取assets中Excel的具体代码,供大家参考,具体内容如下

1.在assets下放的excel表格,命名为excel.xls
2.添加读取excel需要的jar包”jxl.jar”,assets是建在main级别目录下,建错地方找不到文件 

 

3.读取excel中的文件

/*获取excel表格中的数据不能在主线程中调用
   xlsName 为表格的名称
   index 表示第几张表格
   */
  public ArrayList<ExcelBean> getExcelData(String xlsName, int index) {
    ArrayList<ExcelBean> list = new ArrayList<>();
    //获取文件管理器
    AssetManager manager = context.getAssets();
    try {
      Workbook workbook = Workbook.getWorkbook(manager.open(xlsName));
      Sheet sheet = workbook.getSheet(index);
      //表格一共有多少行
      int sheetRows = sheet.getRows();
      //将数据添加到集合中
      for (int i = 0; i < sheetRows; i++) {
        ExcelBean bean = new ExcelBean();
        //获取列的数据
        bean.setChinese(sheet.getCell(0, i).getContents());
        bean.setEnglish(sheet.getCell(1, i).getContents());
        bean.setSpell(sheet.getCell(2, i).getContents());
        list.add(bean);
      }
      workbook.close();
    } catch (Exception e) {
      e.printStackTrace();
    }
    return list;
  }

4.更新UI

public class ExcelDataAsyncTask extends AsyncTask<String, Void, ArrayList<ExcelBean>> {
  private Context context;
  private int index;
  private ExcelData excelData;

  public ExcelDataAsyncTask(Context context, int index, ExcelData excelData) {
    this.context = context;
    this.index = index;
    this.excelData = excelData;
  }

  @Override
  protected ArrayList<ExcelBean> doInBackground(String... params) {
    return getExcelData(params[0], index);
  }

  @Override
  protected void onPostExecute(ArrayList<ExcelBean> excelBeen) {
    super.onPostExecute(excelBeen);
    if (excelBeen != null && excelBeen.size() > 0) {
//      ExcelAdapter adapter=new ExcelAdapter(excelBeen,context);
//      lv.setAdapter(adapter);
      excelData.getData(excelBeen);
    }
  }

/利用接口回调,更新UI
  public interface ExcelData {
    void getData(ArrayList<ExcelBean> list);
  }

Java代码:

 new ExcelDataAsyncTask(ExcelSecondActivity.this, mp3Id, new ExcelDataAsyncTask.ExcelData() {
      @Override
      public void getData(final ArrayList<ExcelBean> list) {
        ExcelAdapter adapter = new ExcelAdapter(list, ExcelSecondActivity.this);
        lv.setAdapter(adapter);
        lv.setOnItemClickListener(new AdapterView.OnItemClickListener() {
          @Override
          public void onItemClick(AdapterView<?> parent, View view, int position, long id) {

             }
        });
      }
    }).execute("excel.xls");

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

相关文章

  • Android垃圾回收机制解决内存泄露问题

    Android垃圾回收机制解决内存泄露问题

    这篇文章主要介绍了Android垃圾回收机制解决内存泄露问题的相关资料,需要的朋友可以参考下
    2016-02-02
  • Android入门之Handler的使用教程详解

    Android入门之Handler的使用教程详解

    这篇文章主要为大家详细介绍了Android中Handler机制的使用,文中的示例代码讲解详细,有需要的朋友可以借鉴参考下,希望能够对大家有所帮助,
    2022-11-11
  • Android自定义View实现五子棋游戏

    Android自定义View实现五子棋游戏

    这篇文章主要为大家详细介绍了Android自定义View实现五子棋游戏,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2019-11-11
  • Android自定义View 实现水波纹动画引导效果

    Android自定义View 实现水波纹动画引导效果

    在android程序开发中,我们经常简单通过自定义view实现水波纹动画引导功能,下面通过本文给大家分享实现代码,需要的朋友参考下
    2017-01-01
  • Java4Android开发教程(一)JDK安装与配置

    Java4Android开发教程(一)JDK安装与配置

    本文是Android开发系列教程的第一篇,主要为大家带来的是开发环境的准备工作,JDK安装与配置图文教程,非常的详细,有需要的朋友可以参考下
    2014-10-10
  • Android如何自定义EditText光标与下划线颜色详解

    Android如何自定义EditText光标与下划线颜色详解

    在android开发中 EditTextText是我们经常用到的,我们使用时会有一些小问题,下面这篇文章主要给大家介绍了关于利用Android如何自定义EditText光标与下划线颜色的相关资料,需要的朋友可以参考借鉴,下面来一起看看吧。
    2017-08-08
  • android不同activity之间共享数据解决方法

    android不同activity之间共享数据解决方法

    最近做局域网socket连接问题,要在多个activity之间公用一个socket连接,就在网上搜了下资料,感觉还是application方法好用,帖出来需要的朋友可以参考下
    2012-11-11
  • Android中LinearLayout布局的常用属性总结

    Android中LinearLayout布局的常用属性总结

    这篇文章主要介绍了Android中LinearLayout布局的常用属性总结,包括居中、重心、比例等线性布局中的基本设置,需要的朋友可以参考下
    2016-04-04
  • Android存储卡读写文件与Application数据保存的实现介绍

    Android存储卡读写文件与Application数据保存的实现介绍

    这篇文章主要介绍了Android在存储卡上读写文件、Application保存数据的实现步骤,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习吧
    2022-09-09
  • Android实现摇一摇简单功能

    Android实现摇一摇简单功能

    这篇文章主要为大家详细介绍了Android实现摇一摇简单功能,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2021-03-03

最新评论