日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程语言 > python >内容正文

python

python打开excel进行编辑_使用Python进行Excel文件处理

發布時間:2023/12/15 python 23 豆豆
生活随笔 收集整理的這篇文章主要介紹了 python打开excel进行编辑_使用Python进行Excel文件处理 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

本章節選自本人著《Python Basic Tutorial》第十五章

15. Excel文件處理

15.1 引言

數據處理是Python的一大應用場景,正如我在本書之前所反復強調的,基于Python活躍及強大的社區,使得Python可以很靈活地處理各種問題。其中,不可置否,Excel是當下最流行的數據處理軟件,而且Python對其的操作也已經擁有大量的第三方庫,這也是非常吸引非計算機行業從事者去使用Python的原因之一。 其中,最常見的有以下幾種:

考慮到大家可能是第一次接觸Python下的Excel處理,由于各自面對的問題或處理方式可能是不一而同的,因此在本書有限的篇幅里可能無法給出直接的案例來概括所有可能要使用的操作。相較而言,xlutils(為書寫方便,剩余篇幅使用xlutils來代替xlutils+xlrd+xlwt)是使用率最高的庫,因此,如果你遇到的問題無法在本書之中尋求到解決方案,你可以很輕松地通過搜索引擎來獲得幫助,所以我們也將其作為教學用例向大家介紹Python下的Excel處理藝術。

15.2 安裝

安裝并不復雜,只是你要按xlrd,xlwt,xlutils的順序依次安裝過去,這三個庫沒有被集中地放在一個包里一直為人所詬病。

15.3 讀取操作

用以上方法就可以對xls文件進行讀取,需要注意的是,直接使用xlrd.openworkbook()進行讀取完后還沒有結束,因為大家在使用Excel的時候,可能會看到左下角不止一張sheet,因此你還需要使用book.sheetby_index()來使用索引作參數來讀取你想要的sheet,而索引是從0而不是從1開始的。或者你可以使用以下方法將所有的sheet全部讀入到一個list里:

在讀取中,xlrd.sheet.Sheet類型常用到的成員方法或屬性有:

15.4 寫入操作

注意,寫入只能是重新創建一個文件,而不能在已有的文件上作寫入操作,至于修改已有文件的方法,會在后文中講到,所以不要著急,先來看下面的代碼:

在寫入中,xlwt.Worksheet.Worksheet類型常用到的成員方法或屬性有:

15.5 修改操作

盡管xlutils已經奇葩到這種程度了,但我依舊推薦大家在入門時去使用它來處理你的Excel數據。修改文件的通常做法是,讀取出文件,復制一份數據,對其進行修改,再保存。 在復制時,需要用到 xlutils 中的copy方法:

如果你想要批量地處理數據,也很簡單,記得我們還可以獲取行數和列數嗎,或者獲取一整列或一整行的內容,你就可以對其進行一個遍歷,或者是做成一個二維list,這就要考驗你list的基本功了。

但有時候我們會注意到在使用copy時,其中字體,文字大小等不會被拷貝,你可以將參數設置如下:

然后在寫入的時候將style作為第四個參數寫入即可:

15.6 一些細節處理

15.6.1 日期轉換

例如我有如下的Excel數據:

我們隊出生年月這一欄的數據讀取時,會發現讀到的會變成浮點數,即它將/當做了除號,進行了運算,真是哭笑不得。 因此處理起來免不了要費一些功夫。首先,我們可以使用以下方法將日期以一個tuple的形式保存下來。

這里還有個題外話,就是我們還可以獲取到單元格里數據的類型。 python讀取excel中單元格的內容返回的有5種類型,以成員變量ctype的形式存儲在sheet.cell里: ctype : 0 empty,1 string, 2 number, 3 date, 4 boolean, 5 error 因此,如果遇到數據類型讀入不確定的情況,你可以做一個判斷,然后再根據具體情況來做出應對方法。

15.6.2 單元格合并問題

當sheet中存在合并單元格的時候,只有第一個小單元格能讀到數據,其他被合并的單元格都是為空的,這個是我覺得這個包功能不完善的地方,如果是合并的單元格那么應該合并的單元格的內容一樣。 這樣的話,有人會說,讀的時候讀第一個單元格,后面如果檢查到類型是空的話,不管不就好了嗎? 疑問又來了,合并單元格可能出現空值,但是表格本身的普通單元格也可能是空值,要怎么獲取單元格所謂的"第一個行或列的索引"呢?

這就要先知道哪些是單元格是被合并的! 讀取文件的時候需要將formatting_info參數設置為True,默認是False,所以上面獲取合并的單元格數組為空,

mergedcells返回的這四個參數的含義是:(row,rowrange,col,colrange),其中[row,rowrange)包括row,不包括rowrange,col也是一樣,即(1, 3, 4, 5)的含義是:第1到2行(不包括3)合并,(7, 8, 2, 5)的含義是:第2到4列合并。 聰明的同學很快就會注意到了,只要取第一個和第三個參數不就行了嗎?是的,獲取mergecells返回的row和col低位的索引即可!這樣的話,合并單元格問題也能得到很好的解決。

15.6.3 結語

對于Python在Excel上的處理的介紹就到此結束,盡管xlutils有種種弊病,但細心研究可以發現,這并不是什么大問題,都可以使用一些trick進行解決,因此,在處理數據的時候,如果一個工具不太好用,不用急著去替換他,而是想一下是不是可以通過自己額外的編程手段去解決它,這樣既可以達成你的目的,又可以提高自己的編程思維與編程技巧。 學有余力的同學,可以查閱我在本篇開頭所介紹的其他幾款工具包,通過對比,一定可以找到適合你遇到的問題的那一個。

本書目錄如下:

總結

以上是生活随笔為你收集整理的python打开excel进行编辑_使用Python进行Excel文件处理的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。