我用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)
全民一起VBA提高篇(Excel數(shù)據(jù)處理)? ?視頻教程下載地址:https://306t.com/file/686368-477372263
更多資源下載地址:https://z701.com/f/686368-485346643-6740b7
(訪問密碼:4939)