你做的excel表格不夠美化簡潔轴咱?教你用Python一招搞定

我用Python爬蟲爬取了全國20多個(gè)圖書館的熱門借閱圖書信息实苞,并按照一定的規(guī)則做了統(tǒng)計(jì)匯總,得到了這一份大學(xué)生各領(lǐng)域必讀TOP150書單质帅,這份書單分領(lǐng)域保存在Excel的50多個(gè)sheet頁中适揉,每個(gè)sheet頁的文件是這樣子的:


原始excel


雖然內(nèi)容非常有價(jià)值,但是酒香也怕巷子深煤惩,這些擠在一塊的內(nèi)容嫉嘀,根本沒有人會有興趣看下去,起碼得調(diào)整一下格式魄揉,做個(gè)簡單的美化剪侮,讓excel更易讀。

如果50多個(gè)shee頁分別去調(diào)格式的話什猖,也是個(gè)不小的工作量票彪,這時(shí)红淡,Python的用武之地就來了不狮!

我可以用Python批量美化這些excel的格式,節(jié)省自己的時(shí)間在旱。

Python對excel的操作我用到了xlwings這個(gè)包摇零。

xlwings能夠非常方便的讀寫Excel文件中的數(shù)據(jù),并且能夠進(jìn)行單元格格式的修改,還可以和matplotlib桶蝎、numpy驻仅、pandas無縫連接,支持讀寫numpy登渣、pandas數(shù)據(jù)類型噪服,并將matplotlib可視化圖表導(dǎo)入到excel中。

更重要的是胜茧,在操作excel的時(shí)候粘优,你可以實(shí)時(shí)看到效果仇味,可以說這是我最喜歡的處理excel的Python包了。

xlwings的使用方式也非常簡單雹顺,只需要:

import?xlwings?as?xw

這里我們主要使用其修改單元格格式的功能丹墨。

分為三步:

第1步,先自己用excel制作一個(gè)格式模板嬉愧,調(diào)整行高贩挣、列寬等,并命名為sample.xlsx没酣。

因?yàn)樾懈吆土袑挾际且恍?shù)值王财,用代碼的方式調(diào)整不太直觀,所以采用在模板e(cuò)xcel上調(diào)整好裕便,然后應(yīng)用到目標(biāo)excel的方式搪搏。制作好的格式模板如下:

格式模板

第2步,讓程序讀取這個(gè)模板里的格式闪金,告訴程序接下來所有的shee頁都按照這個(gè)格式來美化疯溺。


#獲取樣例表格的列寬數(shù)據(jù)def?get_sample_format(col):##因?yàn)闊o需讀取整個(gè)excel所有列的列寬,所以這里傳入一個(gè)讀取的列寬范圍參數(shù)

????wb?=?xw.Book("sample.xlsx")??#?建立于sample.xlsx文件的連接

????sheet?=?wb.sheets["sheet1"]?#打開sample.xlsx文件的sheet1

????format?=?[]for?i?in?range(col):

????????format.append(sheet[0,i].column_width)

????print('列寬:'+str(format))??#'行高:'+sheet.range('A1').column_width+

????wb.close()return?format

第3步哎垦,讓程序批量操作這50個(gè)shee頁囱嫩,按照模板的列寬進(jìn)行設(shè)置,同時(shí)修改一些字體漏设、單元格背景等墨闲。

##?美化表格??

def?beautiful_sheet(table_name,raw,col,format):?????#設(shè)置顏色

????wb2?=?xw.Book(table_name)??#?建立excel表連接

????sheets_name=?[st.name?for?st?in?wb2.sheets]for?st?in??sheets_name:

????????sheet2?=?wb2.sheets[st]#?sheet2[0,0]?=

????????sheet2.range('a1').value=?['序號','書名(@知乎?東寫西讀整理)','總瀏覽次數(shù)','霸榜高校數(shù)','霸榜率','在高校榜單排名中位數(shù)','豆瓣評分','豆瓣鏈接(@知乎?東寫西讀整理)']?#更改標(biāo)題行

????????sheet2[0:raw,0:col+1].api.Borders(12).LineStyle?=?0?#設(shè)置單元格橫邊框?yàn)榧?xì)框線

????????sheet2[0:raw,?0:col+1].api.Borders(11).LineStyle?=?0?#設(shè)置單元格豎邊框?yàn)榧?xì)框線

????????sheet2[0:raw,0:col].api.Font.Name?=?'微軟雅黑'#?設(shè)置字體格式為微軟雅黑

????????sheet2[0:raw,?0:col].api.HorizontalAlignment?=?-4108??#設(shè)置字體居中

????????sheet2[:,4].api.NumberFormat?=?"0%"????#“霸榜率”這一列單元格設(shè)置為百分比格式顯示for?i?in?range(raw):?##行遍歷if?i==0:

????????????????????sheet2[i,?0:col].color?=?[217,?217,?217]?#設(shè)置標(biāo)題背景顏色格式

????????????????elif?i%2?==0:

????????????????????sheet2[i,0:col].color?=?[183,?222,?232]????#設(shè)置偶數(shù)行背景顏色格式為淺藍(lán)色for?i,item?in?enumerate(format):?#列遍歷,根據(jù)sample.xlsx中的列寬進(jìn)行調(diào)整

????????????sheet2[0,i].column_width?=?item

????wb2.save()#保存excel

????wb2.close()#關(guān)閉excelreturn?None

運(yùn)行程序,優(yōu)化后的excel是這個(gè)樣子的:


優(yōu)化后


最后郑口,附上完整代碼:

'''

如有需要Python學(xué)習(xí)資料的小伙伴可以加群領(lǐng)仍П獭:1136201545

'''

import?xlwings?as?xw#獲取樣例表格的列寬數(shù)據(jù)def?get_sample_format(col):##因?yàn)闊o需讀取整個(gè)excel所有列的列寬,所以這里傳入一個(gè)讀取的列寬范圍參數(shù)

????wb?=?xw.Book("sample.xlsx")??#?建立于sample.xlsx文件的連接

????sheet?=?wb.sheets["sheet1"]?#打開sample.xlsx文件的sheet1

????format?=?[]for?i?in?range(col):

????????format.append(sheet[0,i].column_width)

????print('列寬:'+str(format))??#'行高:'+sheet.range('A1').column_width+

????wb.close()return?format?##?美化表格??todo:還需要一個(gè)異常退出??https://blog.csdn.net/qq_37289115/article/details/107322332def?beautiful_sheet(table_name,raw,col,format):?????#設(shè)置顏色

????wb2?=?xw.Book(table_name)??#?建立excel表連接

????sheets_name=?[st.name?for?st?in?wb2.sheets]for?st?in??sheets_name:

????????sheet2?=?wb2.sheets[st]#?sheet2[0,0]?=

????????sheet2.range('a1').value=?['序號','書名(@知乎?東寫西讀整理)','總瀏覽次數(shù)','霸榜高校數(shù)','霸榜率','在高校榜單排名中位數(shù)','豆瓣評分','豆瓣鏈接(@知乎?東寫西讀整理)']?#更改標(biāo)題行

????????sheet2[0:raw,0:col+1].api.Borders(12).LineStyle?=?0?#設(shè)置單元格橫邊框?yàn)榧?xì)框線

????????sheet2[0:raw,?0:col+1].api.Borders(11).LineStyle?=?0?#設(shè)置單元格豎邊框?yàn)榧?xì)框線

????????sheet2[0:raw,0:col].api.Font.Name?=?'微軟雅黑'#?設(shè)置字體格式為微軟雅黑

????????sheet2[0:raw,?0:col].api.HorizontalAlignment?=?-4108??#設(shè)置字體居中

????????sheet2[:,4].api.NumberFormat?=?"0%"????#“霸榜率”這一列單元格設(shè)置為百分比格式顯示for?i?in?range(raw):?##行遍歷if?i==0:

????????????????????sheet2[i,?0:col].color?=?[217,?217,?217]?#設(shè)置標(biāo)題背景顏色格式

????????????????elif?i%2?==0:

????????????????????sheet2[i,0:col].color?=?[183,?222,?232]????#設(shè)置偶數(shù)行背景顏色格式為淺藍(lán)色for?i,item?in?enumerate(format):?#列遍歷,根據(jù)sample.xlsx中的列寬進(jìn)行調(diào)整

????????????sheet2[0,i].column_width?=?item

????wb2.save()#保存excel

????wb2.close()#關(guān)閉excelreturn?Noneif?__name__?==?'__main__':

????table_name?=?"Top150.xlsx"#需要修改的excel名字

????raw?=?151?#需要修改格式的行數(shù)

????col?=?8??##需要修改格式的列數(shù)

????format?=?get_sample_format(col)

????beautiful_sheet(table_name,raw,col,format)

Python


全民一起VBA提高篇(Excel數(shù)據(jù)處理)? ?視頻教程下載地址:https://306t.com/file/686368-477372263


更多資源下載地址:https://z701.com/f/686368-485346643-6740b7

(訪問密碼:4939)

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末犬性,一起剝皮案震驚了整個(gè)濱河市瞻离,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌乒裆,老刑警劉巖套利,帶你破解...
    沈念sama閱讀 212,542評論 6 493
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異鹤耍,居然都是意外死亡肉迫,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,596評論 3 385
  • 文/潘曉璐 我一進(jìn)店門稿黄,熙熙樓的掌柜王于貴愁眉苦臉地迎上來喊衫,“玉大人,你說我怎么就攤上這事杆怕∽骞海” “怎么了鼻听?”我有些...
    開封第一講書人閱讀 158,021評論 0 348
  • 文/不壞的土叔 我叫張陵,是天一觀的道長联四。 經(jīng)常有香客問我撑碴,道長,這世上最難降的妖魔是什么朝墩? 我笑而不...
    開封第一講書人閱讀 56,682評論 1 284
  • 正文 為了忘掉前任醉拓,我火速辦了婚禮,結(jié)果婚禮上收苏,老公的妹妹穿的比我還像新娘亿卤。我一直安慰自己,他們只是感情好鹿霸,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,792評論 6 386
  • 文/花漫 我一把揭開白布排吴。 她就那樣靜靜地躺著,像睡著了一般懦鼠。 火紅的嫁衣襯著肌膚如雪钻哩。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 49,985評論 1 291
  • 那天肛冶,我揣著相機(jī)與錄音街氢,去河邊找鬼。 笑死睦袖,一個(gè)胖子當(dāng)著我的面吹牛珊肃,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播馅笙,決...
    沈念sama閱讀 39,107評論 3 410
  • 文/蒼蘭香墨 我猛地睜開眼伦乔,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了董习?” 一聲冷哼從身側(cè)響起烈和,我...
    開封第一講書人閱讀 37,845評論 0 268
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎阱飘,沒想到半個(gè)月后斥杜,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體虱颗,經(jīng)...
    沈念sama閱讀 44,299評論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡沥匈,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,612評論 2 327
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了忘渔。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片高帖。...
    茶點(diǎn)故事閱讀 38,747評論 1 341
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖畦粮,靈堂內(nèi)的尸體忽然破棺而出散址,到底是詐尸還是另有隱情乖阵,我是刑警寧澤,帶...
    沈念sama閱讀 34,441評論 4 333
  • 正文 年R本政府宣布预麸,位于F島的核電站瞪浸,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏吏祸。R本人自食惡果不足惜对蒲,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 40,072評論 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望贡翘。 院中可真熱鬧蹈矮,春花似錦、人聲如沸鸣驱。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,828評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽踊东。三九已至北滥,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間闸翅,已是汗流浹背碑韵。 一陣腳步聲響...
    開封第一講書人閱讀 32,069評論 1 267
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留缎脾,地道東北人祝闻。 一個(gè)月前我還...
    沈念sama閱讀 46,545評論 2 362
  • 正文 我出身青樓,卻偏偏與公主長得像遗菠,于是被迫代替她去往敵國和親联喘。 傳聞我的和親對象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,658評論 2 350

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