目錄
1.應(yīng)用場景,資料搜索以及思路確認(rèn)
2.DHxlsReader(解讀XLS)
3.利用GDataXML解讀XML的方式來解讀(xlsx)
4.相關(guān)資源鏈接
一.應(yīng)用場景
? ? ? ? 在開發(fā)過程中遇到這樣的需求,要求把APP沙盒的excel文件中的內(nèi)容解析提取出來來使用,比如我有一張聯(lián)系人的表,我要把其中的姓名,電話來提取出來,應(yīng)用到app中去.開始沒有接觸過這方面的知識,于是乎理所當(dāng)然的谷歌百度了一番,資料比較少,而且年代都比較久遠(yuǎn),可能是這方面的需求比較少的原因吧.總之,理一下思路吧先.
? ? ? ? 首先,我們來看一下Excel文件的兩種格式xls和xlsx,格式不一樣,解析的方式也不一樣,區(qū)別的話大家自行百度,簡而言之,在03之前都是xls,后來07版本出現(xiàn)了xlsx。網(wǎng)上有一種方法是先將excel文件轉(zhuǎn)為csv格式的,然后再解析,但是轉(zhuǎn)換的代碼我沒有找到,只是讓客戶在電腦上另存為,這個不合適.后來找到了一個框架,就是DHxlsReader,但是這個只能解析xls后綴格式的.然后xlsx格式的解決方法我是沒有一點頭緒,慚愧.后來是一塊安卓的小伙伴想到的一個方法.后綴為.xlsx的excel文件從本質(zhì)上是一個壓縮文件,解壓打開后的文件夾內(nèi)容格式是固定的,具體的內(nèi)容都放在一個xml文件中,我們要做的就是拿到文件,解析xml,提取內(nèi)容.下面來把具體步驟分享一下.
二 .DHxlsReader(解讀XLS)
? ? ? 這個框架也令我頭疼了一天,因為從github上面下載下來的庫是不能直接使用的,我也不太懂,于是乎又搜索了一下如何用.網(wǎng)上也有demo.因為DHxlsReader是一個項目,所以我們想要用的話,就涉及到一個問題: 如何在你的項目中插入一個新的項目來供你的項目調(diào)用.下面由圖來解.
? 1,將單純的DHxlsReader包含的文件全部拷貝到你的項目中來
2.打開你的項目,點擊左下角加號,選擇addFileTo...
3.這么只添加時沒有關(guān)聯(lián)的,下一步做的是添加關(guān)聯(lián),配置一些環(huán)境,有幾個地方要注意
1添加庫
第一個庫添加的時候可能要注意一點,要點加號,Add Other...,然后command+shift+g, 輸入/usr/lib/ ,你就可以找到了.我導(dǎo)入的時候碰到的問題是明明選擇了 libiconv.dylib, 但是導(dǎo)出后就變成了libiconv.2.dylib, 如果出現(xiàn)這樣的問題,就吧原來的刪掉都統(tǒng)一換成新的庫吧,
2.設(shè)置header search Path
3,因為DHxlsReader中用到了C的庫,所以你的頭文件要加上下圖所示.
我配置的時候弄了一天,碰到各種各樣的問題,因為這方面接觸的不多,后來莫名其妙的就好了,也是無語,查資料的時候,header search path 設(shè)置的地方可能出了問題,但是demo是這么設(shè)置的,我也不甚理解,如果有大神知道,望給我詳細(xì)解一下.
關(guān)于用法,demo里面都有,用法比較簡單,就是環(huán)境配置比較麻煩一點.
三.利用GDataXML解讀XML的方式來解讀(xlsx)
? ? ? ? ?07版之后的excel基本都是xlsx格式的,其本質(zhì)上其實是一個壓縮文件,打開之后是一個文件夾
我們來分析一下這個文件夾的結(jié)構(gòu);shareString是一個公共的字符串池,相當(dāng)于,給我們表中字符串貼上一個標(biāo)簽一樣.然后我們先分析一下shareString.xml里面的內(nèi)容
然后我們先分析一下shareString.xml里面的內(nèi)容
下面來解析worksheet中sheet1.xml
然后就這樣循環(huán)的查下去,把你需要的內(nèi)容查找出來,當(dāng)然,這樣肯定要求excel表格有一定的樣式,最起碼要給你一格標(biāo)識來找到哪一行是姓名,哪一行是號碼,要有幾個模糊關(guān)鍵字讓你來查詢.xlsx文件的解析,我的做法是,先用 ZipArchive 將其解壓到某一個固定的路徑,然后再用GDataXML來解析,兩張表獲取具體內(nèi)容,關(guān)于ZipArchive和GDataXML的使用和注意點,大家自行谷歌吧.思路便是如此了,第一次寫文章,有點繚亂,大家見諒.
四.相關(guān)資源鏈接
1.demo地址:pan.baidu.com/s/1c2lBqBQ?