iOS 如何生成EXCEL文檔和讀取EXCEL文檔

? ? 最近開(kāi)發(fā)一個(gè)藍(lán)牙項(xiàng)目,需要導(dǎo)出和導(dǎo)入EXCEL數(shù)據(jù)肺素,由于之前沒(méi)有接觸這類(lèi)功能,查閱了相關(guān)資料宇驾,最終選擇采用libxlsxwriter庫(kù)實(shí)現(xiàn)EXCEL文檔生成倍靡、CoreXLSX實(shí)現(xiàn)EXCEL文檔內(nèi)容解析,做個(gè)簡(jiǎn)單匯總方便以后查閱课舍,費(fèi)話(huà)不多說(shuō)塌西,直接上干貨。

1筝尾、libxlsxwriter

Libxlsxwriter 是一個(gè) C 庫(kù)雨让,可用于在 Excel 2007+ XLSX 文件中寫(xiě)入文本、數(shù)字忿等、公式和指向多個(gè)工作表的超鏈接栖忠。

具體功能介紹請(qǐng)?zhí)D(zhuǎn)github的庫(kù)地址連接:

1、項(xiàng)目地址

https://github.com/jmcnamara/libxlsxwriter

2贸街、使用手冊(cè)地址

http://libxlsxwriter.github.io/

因?yàn)轫?xiàng)目是用swift開(kāi)發(fā)庵寞,所以這里主要簡(jiǎn)單介紹下swift項(xiàng)目下如何使用:

1.1、準(zhǔn)備好導(dǎo)入數(shù)據(jù)

數(shù)據(jù)格式建議采用Array的方式存儲(chǔ)每一組的數(shù)據(jù)薛匪,方便數(shù)據(jù)寫(xiě)入處理

1.2捐川、創(chuàng)建存儲(chǔ)文件夾路徑

1.3、創(chuàng)建存儲(chǔ)文件

文件名稱(chēng)根據(jù)實(shí)際需求定義逸尖,路徑只需要文件夾路徑拼接文件名即可


1.4古沥、創(chuàng)建EXCEL表格


創(chuàng)建表格過(guò)程如下:

1、生成一張表格

2娇跟、創(chuàng)建一個(gè)sheet

3岩齿、設(shè)置表格的樣式、格式(包含文字格式苞俘、文字顏色盹沈、對(duì)齊方式等)

樣式設(shè)置可參考使用手冊(cè)里的說(shuō)明,這里大概列幾個(gè)供參考:


4吃谣、關(guān)閉表格創(chuàng)建

1.5乞封、查看EXCEL表格是否創(chuàng)建成功

1.5.1做裙、可通過(guò)存儲(chǔ)路徑查看表格是否按我們?cè)O(shè)置樣式生成

如果格式不對(duì)或者樣式不喜歡,可以結(jié)合實(shí)際重新設(shè)置

1.5.2肃晚、通過(guò)QuickLook系統(tǒng)自帶框架打開(kāi)EXCEL文檔

QuickLook的框架詳解請(qǐng)查看:http://www.reibang.com/p/1e886bd9dd51

可以通過(guò)QuickLook打開(kāi)EXCEL文檔锚贱,同時(shí)QuickLook還集成一系列功能(保存文件、傳送文件等)关串,導(dǎo)出文檔功能可用這個(gè)框架實(shí)現(xiàn)拧廊,具體如何導(dǎo)出請(qǐng)看框架詳解說(shuō)明即可

1.6、優(yōu)點(diǎn)

可以通過(guò)設(shè)置樣式創(chuàng)建各種復(fù)雜的EXCEL表格悍缠,文檔說(shuō)明也非常詳細(xì)卦绣,用戶(hù)很容易就可以利用該框架創(chuàng)建滿(mǎn)足各種需求的EXCEL表格

1.7、缺點(diǎn)

沒(méi)有EXCEL讀取功能飞蚓,因此讀取功能只能另外處理

至此滤港,一個(gè)簡(jiǎn)單的EXCEL創(chuàng)建過(guò)程已經(jīng)完成。libxlsxwriter功能十分強(qiáng)大趴拧,如果要生成一個(gè)復(fù)雜的表格溅漾,請(qǐng)仔細(xì)研讀格式設(shè)置說(shuō)明文檔

2、CoreXLSX

CoreXLSX是一個(gè)庫(kù)著榴,它專(zhuān)注于表示基于XML的XLSX電子表格格式的底層結(jié)構(gòu)添履。它允許您打開(kāi)擴(kuò)展名為.xlsx的電子表格存檔,并將其內(nèi)部結(jié)構(gòu)映射到直接用Swift表示的模型類(lèi)型中脑又。

需要注意的是暮胧,此庫(kù)僅為.xlsx格式提供只讀支持。由于舊的legacy.xls電子表格格式具有完全不同的內(nèi)部結(jié)構(gòu)问麸,如果您需要使用該類(lèi)型的文件往衷,請(qǐng)參考其他庫(kù)。

如果您的.xlsx文件使用ECMA-376敏捷加密(這似乎是最流行的一種)严卖,請(qǐng)查看CryptoOffice庫(kù)席舍。

項(xiàng)目地址:https://github.com/CoreOffice/CoreXLSX

2.1、打開(kāi)EXCEL文檔

可通過(guò)系統(tǒng)提供的API打開(kāi)哮笆,如下:


可通過(guò)UIDocumentPickerDelegate回調(diào)方法拿到對(duì)應(yīng)的文件路徑来颤,這里需要注意一個(gè)細(xì)節(jié),如下圖


讀取文件時(shí)需要授權(quán)稠肘,不然有的文件無(wú)法讀取福铅,會(huì)報(bào)沒(méi)有權(quán)限的錯(cuò)誤提示,讀取數(shù)據(jù)完成后启具,需要關(guān)閉授權(quán)


2.2本讥、讀取文檔內(nèi)容

采用CoreXLSX相關(guān)API去讀取數(shù)據(jù),具體可參考項(xiàng)目文檔說(shuō)明鲁冯,因?yàn)轫?xiàng)目在讀取數(shù)據(jù)時(shí)需要校驗(yàn)文檔內(nèi)容是否合法拷沸,不合法需要提示用戶(hù)重新選擇其他文件,校驗(yàn)規(guī)則可根據(jù)實(shí)際需求去做薯演,以下列舉個(gè)人項(xiàng)目的簡(jiǎn)單校驗(yàn)撞芍,如下圖


最終rows得到的就是每組的數(shù)據(jù),可通過(guò)遍歷獲取對(duì)應(yīng)的數(shù)據(jù)跨扮,如有疑問(wèn)序无,請(qǐng)參考官方文檔或者官方DEMO

參考文獻(xiàn):

libxlsxwriter開(kāi)源庫(kù):https://github.com/jmcnamara/libxlsxwriter

CoreXLSX開(kāi)源庫(kù):https://github.com/CoreOffice/CoreXLSX

XlsxReaderWriterSwift開(kāi)源庫(kù):https://github.com/mehulparmar4ever/XlsxReaderWriterSwift

謝謝各位的無(wú)私奉獻(xiàn)酥馍。亿虽。。

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末坟桅,一起剝皮案震驚了整個(gè)濱河市璃氢,隨后出現(xiàn)的幾起案子哟玷,更是在濱河造成了極大的恐慌,老刑警劉巖一也,帶你破解...
    沈念sama閱讀 207,113評(píng)論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件巢寡,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡椰苟,警方通過(guò)查閱死者的電腦和手機(jī)抑月,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,644評(píng)論 2 381
  • 文/潘曉璐 我一進(jìn)店門(mén),熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)舆蝴,“玉大人谦絮,你說(shuō)我怎么就攤上這事〗嗾蹋” “怎么了层皱?”我有些...
    開(kāi)封第一講書(shū)人閱讀 153,340評(píng)論 0 344
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)京痢。 經(jīng)常有香客問(wèn)我奶甘,道長(zhǎng),這世上最難降的妖魔是什么祭椰? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 55,449評(píng)論 1 279
  • 正文 為了忘掉前任臭家,我火速辦了婚禮,結(jié)果婚禮上方淤,老公的妹妹穿的比我還像新娘钉赁。我一直安慰自己,他們只是感情好携茂,可當(dāng)我...
    茶點(diǎn)故事閱讀 64,445評(píng)論 5 374
  • 文/花漫 我一把揭開(kāi)白布你踩。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪带膜。 梳的紋絲不亂的頭發(fā)上吩谦,一...
    開(kāi)封第一講書(shū)人閱讀 49,166評(píng)論 1 284
  • 那天,我揣著相機(jī)與錄音膝藕,去河邊找鬼式廷。 笑死,一個(gè)胖子當(dāng)著我的面吹牛芭挽,可吹牛的內(nèi)容都是我干的滑废。 我是一名探鬼主播,決...
    沈念sama閱讀 38,442評(píng)論 3 401
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼袜爪,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼蠕趁!你這毒婦竟也來(lái)了?” 一聲冷哼從身側(cè)響起辛馆,我...
    開(kāi)封第一講書(shū)人閱讀 37,105評(píng)論 0 261
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤俺陋,失蹤者是張志新(化名)和其女友劉穎,沒(méi)想到半個(gè)月后怀各,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體倔韭,經(jīng)...
    沈念sama閱讀 43,601評(píng)論 1 300
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,066評(píng)論 2 325
  • 正文 我和宋清朗相戀三年瓢对,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了寿酌。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 38,161評(píng)論 1 334
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡硕蛹,死狀恐怖醇疼,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情法焰,我是刑警寧澤秧荆,帶...
    沈念sama閱讀 33,792評(píng)論 4 323
  • 正文 年R本政府宣布,位于F島的核電站埃仪,受9級(jí)特大地震影響乙濒,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜卵蛉,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,351評(píng)論 3 307
  • 文/蒙蒙 一颁股、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧傻丝,春花似錦甘有、人聲如沸。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 30,352評(píng)論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)忱反。三九已至,卻和暖如春滤愕,著一層夾襖步出監(jiān)牢的瞬間温算,已是汗流浹背。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 31,584評(píng)論 1 261
  • 我被黑心中介騙來(lái)泰國(guó)打工该互, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留米者,地道東北人韭畸。 一個(gè)月前我還...
    沈念sama閱讀 45,618評(píng)論 2 355
  • 正文 我出身青樓宇智,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親胰丁。 傳聞我的和親對(duì)象是個(gè)殘疾皇子随橘,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 42,916評(píng)論 2 344

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