您好,登錄后才能下訂單哦!
引
由于需要解決大批量Excel處理的事情,與其手工操作還不如寫個簡單的代碼來處理,大致選了一下感覺還是Python最容易操作。
安裝庫Python環(huán)境
首先當(dāng)然是配環(huán)境,不過選Python的一個重要原因就是Mac內(nèi)是自帶Python環(huán)境的,不需要額外的配置環(huán)境,省下了一筆工作,如果你用的是Windows系統(tǒng),那就還需要配置一下Python的環(huán)境了,我Mac的Python版本是2.7。
第三方庫
Python自己是不支持直接操作Excel的,但是Python強(qiáng)大之處就在于有大量好用的第三方庫,這里我們選用讀Excel的xlrd庫和寫Excel的xlwt庫來操作。
關(guān)于第三方庫的安裝很簡單,首先,去專門下載Python庫的網(wǎng)站下載兩個庫的源碼:
* 下載xlrd
* 下載xlwt
注意對于新手來說最簡單的安裝方式就是源碼安裝,不需要去折騰第三方庫的管理器,直接點(diǎn)擊這個先下載兩個庫的源碼:
你看他后面也描述了類型是源碼嘛。
下載好之后在mac中解壓,得到文件夾,可以看到里面都是有一個 setup.py 文件的:
這里當(dāng)然不是直接雙擊安裝了,py類型表示它是一個Python代碼文件,雙擊只會打開文件看代碼。我們要使用終端,輸入命令號進(jìn)入當(dāng)前所在的文件夾,比如我把文件放在了“下載”中,那么做法是:
$ cd Downloads/
$ cd xlwt-1.1.2
$ sudo python setup.py install
這里 cd 的意思是進(jìn)入該文件夾,sudo 的意思是使用管理員權(quán)限安裝,不使用的話會告訴你沒有權(quán)限的,回車后會要你輸入電腦密碼,輸入后回車即可,python 是執(zhí)行 python代碼文件的命令,install 就是安裝了。
然后會看到刷刷刷一堆文字過去,最后告訴你 finished 了,就是安裝完成了。
xlrd 也是同樣的安裝方式。
寫代碼
讀寫Excel的第三方庫都安裝好了,就可以開始寫代碼了。
我們在一個文件夾下創(chuàng)建一個 hello.py 文件,然后用sublime之類的文檔編輯器打開它,開始編寫代碼。(PS:Python中 # 號開頭表示注釋)
讀Excel
# -*- coding: utf-8 -*- import xdrlib ,sys import xlrd #打開excel文件 def open_excel(file= 'test.xlsx'): try: data = xlrd.open_workbook(file) return data except Exception,e: print str(e) #根據(jù)名稱獲取Excel表格中的數(shù)據(jù) 參數(shù):file:Excel文件路徑 colnameindex:表頭列名所在行的索引 ,by_name:Sheet1名稱 def excel_table_byname(file= 'test.xlsx', colnameindex=0, by_name=u'Sheet1'): data = open_excel(file) #打開excel文件 table = data.sheet_by_name(by_name) #根據(jù)sheet名字來獲取excel中的sheet nrows = table.nrows #行數(shù) colnames = table.row_values(colnameindex) #某一行數(shù)據(jù) list =[] #裝讀取結(jié)果的序列 for rownum in range(0, nrows): #遍歷每一行的內(nèi)容 row = table.row_values(rownum) #根據(jù)行號獲取行 if row: #如果行存在 app = [] #一行的內(nèi)容 for i in range(len(colnames)): #一列列地讀取行的內(nèi)容 app.append(row[i]) list.append(app) #裝載數(shù)據(jù) return list #主函數(shù) def main(): tables = excel_table_byname() for row in tables: print row if __name__=="__main__": main()
這個代碼很多我都注釋了,只講幾個要注意的地方,首先最開始我們設(shè)置了utp8編碼,然后一定要記得導(dǎo)入xlrd包,這樣才能使用它的函數(shù)去讀取excel。里面的 main() 是主函數(shù),python 會運(yùn)行這個函數(shù),這個函數(shù)調(diào)用了其余的函數(shù)來讀取數(shù)據(jù)。這個代碼實(shí)現(xiàn)的是將excel文件 test.xlsx 中的 Sheet1 表中的數(shù)據(jù)一行行讀取出來并打印。
Excel中內(nèi)容如下:
有兩行內(nèi)容。
要運(yùn)行這個代碼,需要用終端使用命令行,首先 cd 進(jìn)入到代碼所在的文件夾,代碼和Excel文件都要放在這個文件夾里。然后使用 python hello.py 命令來運(yùn)行這個代碼文件:
以上就是 Python 讀取并打印出來的內(nèi)容,u 表示使用的是unicode編碼,可以看到與Excel中是一致的。
創(chuàng)建Excel
使用xlwt庫我們可以創(chuàng)建一個Excel:
# -*- coding: utf-8 -*- import xlwt def testXlwt(file = 'new.xls'): book = xlwt.Workbook() #創(chuàng)建一個Excel sheet1 = book.add_sheet('hello') #在其中創(chuàng)建一個名為hello的sheet sheet1.write(0,0,'cloudox') #往sheet里第一行第一列寫一個數(shù)據(jù) sheet1.write(1,0,'ox') #往sheet里第二行第一列寫一個數(shù)據(jù) book.save(file) #創(chuàng)建保存文件 #主函數(shù) def main(): testXlwt() if __name__=="__main__": main()
這個代碼更簡單,同樣記得要在開頭導(dǎo)入庫。
代碼中我們創(chuàng)建了一個excel,在其中添加一個sheet,寫入兩個數(shù)據(jù),最后按照我們的命名保存了文件。
按照上面同樣的方法運(yùn)行代碼后,終端中不會有打印的內(nèi)容,但是我們?nèi)ノ募A中看會得到一個名為 new.xls 的新excel文件,打開可以看到:
按照我們的方法寫了數(shù)據(jù),同時sheet名字也是hello。
值得注意的是,在xlwt庫的說明中有這么一句話:
Library to create spreadsheet files compatible with MS Excel 97/2000/XP/2003 XLS files, on any platform, with Python 2.6, 2.6, 3.3+
也就是說,它只能創(chuàng)建 xls 的文件格式,不能創(chuàng)建現(xiàn)在的 xlsx 格式,其實(shí)有點(diǎn)老了,如果你把文件名寫了 xlsx 格式,將會無法打開。
處理Excel內(nèi)容
其實(shí)單獨(dú)的讀和寫只是基本功,我們最終是想要處理Excel中的內(nèi)容的。
這里我們假設(shè)一個使用場景,我們希望將Excel中所有第一列和第二列相同的行數(shù)據(jù)篩選出來保存到一個新的Excel中去。
那么我們的流程是:
打開目標(biāo)Excel讀取內(nèi)容讀取每一行的同時篩選第一列和第二列相等的行保留下來創(chuàng)建一個新Excel將篩選出來的內(nèi)容寫進(jìn)去保存新Excel
那么我們看代碼:
# -*- coding: utf-8 -*- import xdrlib ,sys import xlrd import xlwt #打開excel文件 def open_excel(file= 'test.xlsx'): try: data = xlrd.open_workbook(file) return data except Exception,e: print str(e) #根據(jù)索引獲取Excel表格中的數(shù)據(jù) 參數(shù):file:Excel文件路徑 colnameindex:表頭列名所在行的索引 ,by_index:表的索引 def excel_table_byindex(file= 'test.xlsx',colnameindex=0,by_index=0): data = open_excel(file) #打開excel文件 table = data.sheets()[by_index] #根據(jù)sheet序號來獲取excel中的sheet nrows = table.nrows #行數(shù) ncols = table.ncols #列數(shù) colnames = table.row_values(colnameindex) #某一行數(shù)據(jù) list =[] #裝讀取結(jié)果的序列 for rownum in range(0,nrows): #遍歷每一行的內(nèi)容 row = table.row_values(rownum) #根據(jù)行號獲取行 if row: #如果行存在 app = [] #一行的內(nèi)容 for i in range(len(colnames)): #一列列地讀取行的內(nèi)容 app.append(row[i]) if app[0] == app[1] : #如果這一行的第一個和第二個數(shù)據(jù)相同才將其裝載到最終的list中 list.append(app) testXlwt('new.xls', list) #調(diào)用寫函數(shù),講list內(nèi)容寫到一個新文件中 return list #將list中的內(nèi)容寫入一個新的file文件 def testXlwt(file = 'new.xls', list = []): book = xlwt.Workbook() #創(chuàng)建一個Excel sheet1 = book.add_sheet('hello') #在其中創(chuàng)建一個名為hello的sheet i = 0 #行序號 for app in list : #遍歷list每一行 j = 0 #列序號 for x in app : #遍歷該行中的每個內(nèi)容(也就是每一列的) sheet1.write(i, j, x) #在新sheet中的第i行第j列寫入讀取到的x值 j = j+1 #列號遞增 i = i+1 #行號遞增 # sheet1.write(0,0,'cloudox') #往sheet里第一行第一列寫一個數(shù)據(jù) # sheet1.write(1,0,'ox') #往sheet里第二行第一列寫一個數(shù)據(jù) book.save(file) #創(chuàng)建保存文件 #主函數(shù) def main(): tables = excel_table_byindex() for row in tables: print row if __name__=="__main__": main()
這次我們開頭要導(dǎo)入xlrd和xlwt兩個庫,因?yàn)榧纫x也要寫。
代碼內(nèi)容基本與上面兩個差不多,有一點(diǎn)點(diǎn)加深,在讀取的時候我們判斷了第一列和第二列數(shù)據(jù)相同的行才加到list中去。在寫的時候我們用了兩個for循環(huán)來對新excel中的一個個單元格寫數(shù)據(jù),使用了i和j兩個變量來記錄位置。此外在獲取sheet的時候,與上面的不同,這里是通過sheet的序號(這里是0)來獲取的,上面的是通過sheet名稱來獲取。
我們要處理的Excel中的內(nèi)容是這樣的:
按道理我們篩選后只應(yīng)該保留第一行的內(nèi)容,運(yùn)行完后我們得到了一個新的Excel文件,里面的內(nèi)容如下:
可以看到和預(yù)期是相符的。
結(jié)
這里只是簡單的例子,兩個庫的操作還有很多,能夠進(jìn)行的處理也有很多,如果要處理大量數(shù)據(jù),可能還要考慮內(nèi)存,分批次來處理,總之,本文只是一個入門,盡量追求零基礎(chǔ)也能學(xué)著使用來解放勞動力,更多的用法,就看自己琢磨了。
可以下載我的示例工程:https://github.com/Cloudox/PYReadWriteExcelDemo
以上所述是小編給大家介紹的Python讀寫處理Excel表格詳解整合,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復(fù)大家的。在此也非常感謝大家對億速云網(wǎng)站的支持!
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報,并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。