Android 中讀取Excel文件實(shí)例詳解
Android 中讀取Excel文件實(shí)例詳解
最近有個(gè)需求需要在app內(nèi)置數(shù)據(jù),新來(lái)的產(chǎn)品扔給了我兩個(gè)Excel表格就不管了(兩個(gè)表格格式還不統(tǒng)一。。。),于是通過(guò)度娘等方法找到了Android中讀取Excel表格文件的一種方法,記錄一下。
閑話一下Excel中工作簿和工作表的區(qū)別:
工作簿中包含有工作表。工作簿可以由一張或多張工作表組成,一個(gè)工作簿就是一個(gè)EXCEL表格文件。
好了,開(kāi)始讀取表格文件吧。
前提
首先,我們假設(shè)需要讀取的表格文件名字為test.xls, 位于assets根目錄下。
所需Jar包
這里為了能讀取到Excel表格文件,我們要添加一個(gè)第三方Jar包jxl。
這里有點(diǎn)兒需要注意的地方:由于表格文件格式較多,老版本的jxl后只支持Excel2003版本的,所以如果拿到的表格文件格式是xlsm或者xlsn之類的,我們首先要把文件另存為xls格式。
開(kāi)始讀取
1.初始化變量:
InputStream inputStream = null;//輸入流 FileOutputStream outputStream = null;//輸出流 Workbook book = null;//Excel工作簿對(duì)象
2.以流的方式讀取我們內(nèi)置在assets目錄下的表格文件
inputStream = context.getAssets().open("test.xls");
3.將上一步的輸入流讀取成一個(gè)文件,方便后續(xù)使用
File tempFile = new File(context.getCacheDir(), "test.xls");//臨時(shí)文件,第二個(gè)參數(shù)為文件名字,可隨便取
outputStream = new FileOutputStream(tempFile);
byte[] buf = new byte[1024];
int len;
while ((len = inputStream.read(buf)) > 0) {//while循環(huán)進(jìn)行讀取
outputStream.write(buf, 0, len);
}
outputStream.close();
inputStream.close();
4.得到Excel文件對(duì)象后,就可以利用jxl包中提供的各種方法來(lái)操作表格文件。jxl提供的方法很多,這里簡(jiǎn)單介紹下項(xiàng)目中用到的幾個(gè)。
book = Workbook .getWorkbook(tempFile);//用讀取到的表格文件來(lái)實(shí)例化工作簿對(duì)象(符合常理,我們所希望操作的就是Excel工作簿文件)
Sheet[] sheets = book.getSheets(); //得到所有的工作表
for (int m = 0; m < sheets.length; m++) {
Sheet sheet = book.getSheet(m);
int Rows = sheet.getRows();//得到當(dāng)前工作表的行數(shù)
int Cols = sheet.getColumns(); //得到當(dāng)前工作表的列數(shù)
for (int i = 0; i < Cols; i++) { // 注意:這里是按列讀取的?。?!
for (int j = 0; j < Rows; j++) {
String content=sheet.getCell(i, j).getContents();//結(jié)果是String類型的,根據(jù)具體需求進(jìn)行類型轉(zhuǎn)換
}
}
}
總結(jié)
如果表格文件是內(nèi)置在assets目錄下的話,按照以上流程讀取即可,如果是在sd卡之類的話,步驟基本一致,都是首先得到我們的表格文件,然后得到工作簿對(duì)象,對(duì)其進(jìn)行操作。
感謝閱讀,希望能幫助到大家,謝謝大家對(duì)本站的支持!
- Android應(yīng)用讀取Excel文件的方法
- Android實(shí)現(xiàn)仿excel數(shù)據(jù)表格效果
- Android操作Excel文件的功能實(shí)現(xiàn)
- android通過(guò)jxl讀excel存入sqlite3數(shù)據(jù)庫(kù)
- Android開(kāi)發(fā)實(shí)現(xiàn)生成excel的方法詳解
- android讀取assets中Excel表格并顯示
- Android開(kāi)發(fā)實(shí)現(xiàn)的導(dǎo)出數(shù)據(jù)庫(kù)到Excel表格功能【附源碼下載】
- Android 操作excel功能實(shí)例代碼
- Android開(kāi)發(fā)實(shí)現(xiàn)讀取excel數(shù)據(jù)并保存為xml的方法
- Android多國(guó)語(yǔ)言轉(zhuǎn)換Excel及Excel轉(zhuǎn)換為string詳解
相關(guān)文章
Android Button按鈕點(diǎn)擊背景和文字變化操作
這篇文章主要介紹了Android Button按鈕點(diǎn)擊背景和文字變化操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2020-08-08
Android內(nèi)嵌Unity并實(shí)現(xiàn)互相跳轉(zhuǎn)的實(shí)例代碼
這篇文章主要介紹了Android內(nèi)嵌Unity并實(shí)現(xiàn)互相跳轉(zhuǎn)的實(shí)例代碼,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-11-11
Android?Navigation重建Fragment問(wèn)題分析及解決
這篇文章主要介紹了Android?Navigation重建Fragment問(wèn)題分析及解決,文章通過(guò)圍繞主題展開(kāi)詳細(xì)的內(nèi)容介紹,具有一定的參考價(jià)值,需要的小伙伴可以參考一下2022-09-09
Android Handler之消息循環(huán)的深入解析
本篇文章是對(duì)Handler消息循環(huán)進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下2013-05-05
android+json+php+mysql實(shí)現(xiàn)用戶反饋功能方法解析
相信每個(gè)項(xiàng)目都會(huì)有用戶反饋建議等功能,這個(gè)實(shí)現(xiàn)的方法很多,下面是我實(shí)現(xiàn)的方法,供大家交流2012-11-11
java從輸入流中獲取數(shù)據(jù)并返回字節(jié)數(shù)組示例
這篇文章主要介紹了java從輸入流中獲取數(shù)據(jù)并以字節(jié)數(shù)組返回,這是一個(gè)常用的方法,以后可以直接拿來(lái)用。這種輸入流可以來(lái)自Android本地,也可以來(lái)自網(wǎng)絡(luò)2014-01-01
Android 動(dòng)態(tài)加載二維碼視圖生成快照的示例
本篇文章主要介紹了Android 動(dòng)態(tài)加載二維碼視圖生成快照的示例,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2017-10-10
Android通過(guò)應(yīng)用程序創(chuàng)建快捷方式的方法
這篇文章主要介紹了Android通過(guò)應(yīng)用程序創(chuàng)建快捷方式的方法,涉及Android基于應(yīng)用程序創(chuàng)建快捷方式的圖標(biāo)及動(dòng)作等技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下2015-09-09
Android解析json數(shù)據(jù)示例代碼(三種方式)
本篇文章主要介紹了Android解析json數(shù)據(jù)示例代碼,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2017-03-03

