mac os 解析excel

使用SSZipArchive解壓excel文件獲得一個文件锋拖,SSZipArchive解壓的時候會指定一個路徑,解壓完成的文件通過路徑獲得,文件夾的目錄是這樣的


9E7A5294-9AC9-4C70-8C13-97EA24F9E4B6.png

當前解析的表格如下:


image.png

這里只需要關注xl這個文件夾垒在,接下來解釋下每個文件夾對應的每個xml的作用。
-----------------------------------------分割線---------------------------------------------

1.解析sheet

image.png

上圖中這兩個sheet1和sheet2分別代表了excel中的2018.11.12-2018.11.17 和 2018.11.12-2018.11.17 场躯。 需要我們解析拿到數(shù)據(jù)谈为。


image.png
<cols>
    <col min="1" max="1" width="13" customWidth="1"/>
    <col min="2" max="2" width="15" customWidth="1"/>
    <col min="3" max="3" width="16.83203125" customWidth="1"/>
    <col min="4" max="4" width="16.6640625" customWidth="1"/>
    <col min="5" max="5" width="16" customWidth="1"/>
  </cols>

這個只是表示了excel每個col(單元格)的寬度踢关,不用管。

<sheetData>
    <row r="1" spans="1:5" ht="18">
      <c r="A1" s="1" t="s">
        <v>0</v>
      </c>
      <c r="B1" s="1" t="s">
        <v>1</v>
      </c>
      <c r="C1" s="5" t="s">
        <v>2</v>
      </c>
      <c r="D1" s="1" t="s">
        <v>3</v>
      </c>
      <c r="E1" s="1" t="s">
        <v>4</v>
      </c>
    </row>
</sheetData>

<row>...</row>里面代表了每一行签舞,
<c ...>...</c> 代表了一個單元格
r="A1" 代表了這個單元格是在excel中的A1位置秕脓。
s 這個沒用到所以沒有研究,有興趣的可以查一下吠架。
t 和 v 這兩個節(jié)點下面講搂鲫。

2. 給每一個單元格確定數(shù)據(jù)傍药。

解析sharedStrings.xml


image.png

之前解析了那么可以看到我們需要的數(shù)據(jù)都在這里,數(shù)據(jù)是有了魂仍,那我們怎么給每一個單元格賦值呢拐辽?接下來講一下上面說到的 節(jié)點t 和 v的作用蓄诽。
v: v這個節(jié)點代表了每個col(單元格)的數(shù)據(jù)在sharedStrings.xml的下標媒吗,比如:

<c r="B1" s="1" t="s">
    <v>1</v>
</c>

代表了B1這個col的數(shù)據(jù)是sharedStrings.xml 中的下標為1的數(shù)據(jù)就是'人名'
t:這個節(jié)點曾經(jīng)困惑我很久的一段時間仑氛,按照上面的流程看似一切美好闸英,實則暗藏伏擊,如果你的單元格內(nèi)是文字按照流程一切照好甫何,但是如果有數(shù)字在通過v取值就取不到。
PS:excel的每一個col會有很多格式辙喂,比如


image.png

比如下面這個節(jié)點


image.png

所以t的作用就是判斷 有沒有這個t節(jié)點巍耗,
if ([@"t" isEqualToString @"s"]){
  //從sharedStrings.xml 中取
}else{
  //取v 當作col內(nèi)的值
}

注:如果col內(nèi)是date格式 這個v就是從1970 到現(xiàn)在的天數(shù),如果有人需要可以留言炬太,我發(fā)我的計算公式。
現(xiàn)在所有數(shù)據(jù)都已經(jīng)處理完成了亲族,但是我們現(xiàn)在還不知道sheet1 和 sheet2 到底哪個是對應的2018.11.12-2018.11.17 可缚、2018.11.20-2018.11.25斋枢。

3.sheet 與 xml 的對應關系

(1).workbook.xml.rels

最后一步,獲取對應關系杏慰。


image.png

workbook.xml.rels 這個xml文件記錄了表格中每個sheet 與每個xml的對應關系,說白了就是一個表格中的sheet1 和 sheet2 這兩個不一樣的sheet 分別有不同的xml文件轰胁,這就需要一個標示讓我們?nèi)フ业绞窃鯓訉模奖憬馕觥?/p>

image.png

上圖是workbook.xml.rels的內(nèi)容可以看到
<Relationship Id="rId2" Type="http://schemas.openxmlformats.org/officeDocument/2006/relationships/worksheet" Target="worksheets/sheet2.xml"/>
<Relationship Id="rId1" Type="http://schemas.openxmlformats.org/officeDocument/2006/relationships/worksheet" Target="worksheets/sheet1.xml"/>

這兩句中的Id 對應關系的關鍵 赃阀。


image.png

上圖是當前解析的excel

(2).workbook.xml

上面弄明白了workbook.xml.rels擎颖,接下來看workbook.xml這個xml文件。


image.png

我們可以看到這個代碼

 <sheets>
    <sheet name="2018.11.12-2018.11.17" sheetId="1" r:id="rId1"/>
    <sheet name="2018.11.20-2018.11.25" sheetId="2" r:id="rId2"/>
  </sheets>

這個r:id 就是對應關系的重要部分
我介紹的有點繁瑣了驮俗,就是怕我講的不夠詳細允跑,簡單總結下:
通過workbook.xml.rels中的Id="rId2" 與 workbook.xml中的r:id="rId2" 我們可以知道 這個sheet2的sheet名叫2018.11.20-2018.11.25

4.每個單元格的樣式

styles.xml
theme1.xml
2019.4.2更新
今天用到了單元格的樣式王凑,這里介紹一下
每一個col 都有一個s節(jié)點聋丝,通過這個s索引的值 取cellXfs

image.png

cellXfs 中包含了 各種id fillId borderId 這里以fillId為例,
通過fillId這個索引的值 取fills
image.png

fills數(shù)組的元素就是當前col的填充色百姓,borderId等都同理

5.最后

解析excel看似繁瑣,實則就是考驗對xml的解析垒拢,一切都是有規(guī)律火惊,有問題請留言子库,我盡量會解答問題矗晃。demo我會利用空余時間整理一份出來。

最后編輯于
?著作權歸作者所有,轉載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市鸵贬,隨后出現(xiàn)的幾起案子脖捻,更是在濱河造成了極大的恐慌阔逼,老刑警劉巖地沮,帶你破解...
    沈念sama閱讀 216,544評論 6 501
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異摩疑,居然都是意外死亡,警方通過查閱死者的電腦和手機吉殃,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,430評論 3 392
  • 文/潘曉璐 我一進店門蛋勺,熙熙樓的掌柜王于貴愁眉苦臉地迎上來鸠删,“玉大人刃泡,你說我怎么就攤上這事家卖。” “怎么了馒闷?”我有些...
    開封第一講書人閱讀 162,764評論 0 353
  • 文/不壞的土叔 我叫張陵,是天一觀的道長疏虫。 經(jīng)常有香客問我呢袱,道長羞福,這世上最難降的妖魔是什么治专? 我笑而不...
    開封第一講書人閱讀 58,193評論 1 292
  • 正文 為了忘掉前任,我火速辦了婚禮挟炬,結果婚禮上,老公的妹妹穿的比我還像新娘老速。我一直安慰自己额湘,他們只是感情好锋华,可當我...
    茶點故事閱讀 67,216評論 6 388
  • 文/花漫 我一把揭開白布磺樱。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪侵续。 梳的紋絲不亂的頭發(fā)上状蜗,一...
    開封第一講書人閱讀 51,182評論 1 299
  • 那天警儒,我揣著相機與錄音,去河邊找鬼记劝。 笑死厌丑,一個胖子當著我的面吹牛怒竿,可吹牛的內(nèi)容都是我干的耕驰。 我是一名探鬼主播,決...
    沈念sama閱讀 40,063評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼媒抠,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了舍咖?” 一聲冷哼從身側響起,我...
    開封第一講書人閱讀 38,917評論 0 274
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎后裸,沒想到半個月后微驶,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體因苹,經(jīng)...
    沈念sama閱讀 45,329評論 1 310
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,543評論 2 332
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片解虱。...
    茶點故事閱讀 39,722評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡阻课,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出员凝,到底是詐尸還是另有隱情旺上,我是刑警寧澤宣吱,帶...
    沈念sama閱讀 35,425評論 5 343
  • 正文 年R本政府宣布杭攻,位于F島的核電站兆解,受9級特大地震影響锅睛,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜具练,卻給世界環(huán)境...
    茶點故事閱讀 41,019評論 3 326
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望陵究。 院中可真熱鬧,春花似錦寨蹋、人聲如沸秸苗。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,671評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至侣诺,卻和暖如春年鸳,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背膳算。 一陣腳步聲響...
    開封第一講書人閱讀 32,825評論 1 269
  • 我被黑心中介騙來泰國打工映琳, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留萨西,地道東北人谎脯。 一個月前我還...
    沈念sama閱讀 47,729評論 2 368
  • 正文 我出身青樓,卻偏偏與公主長得像,于是被迫代替她去往敵國和親僵朗。 傳聞我的和親對象是個殘疾皇子验庙,可洞房花燭夜當晚...
    茶點故事閱讀 44,614評論 2 353

推薦閱讀更多精彩內(nèi)容