在script里調整字體大小代碼(scripts怎么調中文)
Python對Excel表格處理非常方便,本文專門對Excel單元格樣式設置進行總結,日常用到的設置基本都可以用openpyxl庫完成。
創(chuàng)建一個表格
openpyxl是第三方庫,如果你還沒有安裝,輸入下方命令安裝。
pip install openpyxl
在開始設置單元格前,先創(chuàng)建一個excel表格,下方代碼可以新建一個Excel表格,并寫入內容。
# coding=utf-8
importopenpyxl
# 創(chuàng)建一個excel表格對象
wb = openpyxl.Workbook
# 獲取當前活躍的sheet頁,默認就是第一個sheet頁
ws = wb.active
# 在表格的單元格中寫入內容
ws.cell(row= 2, column= 3).value = '小斌哥ge'
ws.cell(row= 2, column= 4).value = '小斌哥ge'
# 處理完成后保存表格,會在當前目錄生成一個excel文件
wb.save(filename= 'cell.xlsx')
展開全文
# 關閉表格對象
wb.close
效果:
代碼含義參考注釋,我在兩個相鄰的單元格中寫入了相同的內容,后面的代碼對一個單元格設置樣式,另一個單元格不做處理,方便對比。
給單元格寫入內容的方式有兩種,一種是給cell的value屬性賦值,如上面的代碼,另一種是用cell的參數(shù)設置,如ws.cell(row=2, column=3, value='xxx'),兩種方式結果一樣。
本文后面的代碼全部都添加在單元格寫入內容后,保存內容(wb.save)前,順序不能弄反了。(導包的代碼可以統(tǒng)一放到前面)
單元格字體和文字樣式
fromopenpyxl.styles importFont
# 設置字體和文字樣式
font = Font(name= "微軟雅黑", size= 12, color= 'FF0000', bold= True,
italic= True, underline= 'single', strike= False)
ws.cell(row= 2, column= 3).font = font
效果:
字體和文字樣式使用Font類設置,賦值給cell的font屬性。
Font類常用參數(shù)說明:
name: 字體名稱。
size: 字體大小。
color: 字體顏色。使用16進制的RGB顏色值,這里的顏色值中沒有#。
bold: 設置字體加粗,布爾值。
italic: 設置字體傾斜,布爾值。
underline: 設置下劃線的樣式,默認沒有。共有 single, double, singleAccounting, doubleAccounting 四種選擇,single單線,double雙線,不帶Accounting長度與文字一致,帶Accounting長度與單元格寬度一致。
strike: 設置中劃線,布爾值。
設置單元格高和寬
# 設置寬高
# row_dimensions中指定要設置高度的行
ws.row_dimensions[ 2].height = 50
# column_dimensions中指定要設置寬度的列
ws.column_dimensions[ 'C'].width = 20
效果:
單元格的高和寬不是按單元格設置,而是按行和按列設置,因為Excel中同一行的高度和同一列的寬度相同。
設置方法:
ws.row_dimensions[2].height: 設置第2行的高。
ws.column_dimensions['C'].width: 設置C列的寬。
注意,指定行時使用數(shù)字,指定列時使用大寫字母。這與Excel的行列編號一致。
單元格對齊方式
fromopenpyxl.styles importAlignment
# 設置內容的對齊方式
align = Alignment(horizontal= 'left', vertical= 'center', text_rotation= 0,
wrap_text= True, shrink_to_fit= True, indent= 1)
ws.cell(row= 2, column= 3).alignment = align
效果:
單元格對齊方式使用Alignment類設置,賦值給cell的alignment屬性。
Alignment類常用參數(shù)說明:
horizontal: 水平方向對齊方式。默認general(常規(guī)),可以設置為:left(左對齊),center(居中),right(右對齊),distributed(分散對齊),centerContinuous(跨列居中),justify(兩端對齊),fill(填充)。
vertical: 垂直方向對齊方式??梢栽O置為:top(頂端對齊),center(居中), bottom(底部對齊),justify(兩端對齊),distributed(分散對齊)。
text_rotation: 單元格旋轉角度。旋轉方向為逆時針,旋轉后內容排列方向發(fā)生變化。
wrap_text: 設置自動換行,布爾值。
shrink_to_fit: 內容自適應單元格大小,布爾值。
indent: 縮進,傳入縮進的字符數(shù)。
單元格填充顏色
fromopenpyxl.styles importPatternFill
# 設置單元格填充顏色和樣式
pattern = PatternFill(fill_type= 'lightUp', start_color= "0000FF", end_color= '00FF00')
ws.cell(row= 2, column= 3).fill = pattern
效果:
單元格填充顏色使用PatternFill類設置,賦值給cell的fill屬性。
PatternFill類參數(shù)說明:
fill_type: 填充樣式,如完整填充,虛線填充,斜線填充等,通常使用solid??梢栽O置的樣式有: lightTrellis, lightGray, mediumGray, darkHorizontal, lightHorizontal, darkGrid, darkDown, gray0625, lightDown, solid, darkTrellis, lightVertical, lightUp, gray125, lightGrid, darkVertical, darkGray, darkUp, 就不一一介紹了,可以自己多嘗試。
start_color: 設置填充顏色。顏色值與前面一樣,使用16進制的RGB顏色值,不帶#。
end_color: 設置背景顏色。如果填充顏色沒有填滿(例如斜線填充),空隙處看到的是背景顏色。
PatternFill類還有三個參數(shù),與上面的三個參數(shù)作用是重復的,patternType等價于fill_type,fgColor等價于start_color,bgColor等價于end_color。openpyxl單元格設置的好幾個類都有這種參數(shù)重復的情況,其他類就不重復介紹了。
單元格填充漸變顏色
fromopenpyxl.styles importGradientFill
# linear模式,根據(jù)stop設置的多個顏色漸變填充,degree設置順時針的旋轉角度
# gradient = GradientFill(type='linear', degree=30,
# stop=('FF0000', '00FF00', '0000FF'))
# path模式,根據(jù)stop設置的多個顏色從左上角至右下角、由內至外填充,
# left,right,top,bottom設置上下左右距離邊框的距離百分比
gradient = GradientFill(type= 'path', left= 0.1, right= 0.1, top= 0.1, bottom= 0.1,
stop=( 'FF0000', '00FF00', '0000FF'))
# ws.cell(row=2, column=3).fill = gradient
效果:
linear模式
path模式
單元格填充漸變顏色使用GradientFill類設置,賦值給cell的fill屬性。
GradientFill類參數(shù)說明:
type: 填充模式,分為兩種模式'linear'、'path'。
stop: 設置漸變填充用的多個顏色,傳入一個由RGB顏色值組成的元組。
linear模式:根據(jù)stop設置的多個顏色從左至右漸變填充。
degree: 設置漸變填充顏色順時針的旋轉角度。
path模式:根據(jù)stop設置的多個顏色從左上角至右下角、由內至外漸變填充。
left: 設置顏色到左邊框的距離百分比(具體請看截圖的效果),設置為0到1的小數(shù)。
right: 設置顏色到右邊框的距離百分比。
top: 設置顏色到上邊框的距離百分比。
bottom: 設置顏色到下邊框的距離百分比。四個值可以不同。
設置單元格邊框樣式
fromopenpyxl.styles importSide, Border
# 設置線條的樣式和顏色
side = Side(style= "thick", color= "FF0000")
# 設置單元格的邊框線條
border = Border(top=side, bottom=side, left=side, right=side)
ws.cell(row= 2, column= 3).border = border
效果(為了顯示得更明顯,先將顏色填充的代碼注釋掉):
單元格邊框樣式使用Border類設置,賦值給cell的border屬性。邊框線條的樣式使用Side類設置,傳給Border類中的參數(shù)。
Side類參數(shù)說明:
style: 設置線條樣式,常用樣式有medium, thin, thick??梢栽O置的樣式有: dashDotDot, thick, mediumDashDotDot, thin, dotted, mediumDashed, dashDot, double, medium, hair, mediumDashDot, dashed, slantDashDot, 不一一介紹,可以自己多嘗試。
color: 設置線條顏色。
Border類常用參數(shù)說明:
top: 設置單元格的上邊框,傳入Side類實例。
bottom: 設置單元格的下邊框。
left: 設置單元格的左邊框。
right: 設置單元格的右邊框。
注意,設置單元格邊框樣式時,前面設置單元格對齊方式中的單元格旋轉參數(shù)text_rotation會影響邊框的角度,可以根據(jù)需要配合修改,通常設置text_rotation為0。
Border類中,還有一些其他參數(shù),outline設置整個單元格的邊框,vertical設置垂直方向,horizontal設置水平方向,diagonal設置對角線, diagonal_direction設置對角線的角度,不過openpyxl有些版本不支持這些參數(shù)。所以,統(tǒng)一使用上下左右就行了,而且這樣可以給不同邊設置不一樣的 樣式。
使用openpyxl內置樣式
# 使用內置樣式
ws.cell(row= 2, column= 3).style = 'Title'
效果:
openpyxl內置了很多設置好的樣式,可以直接賦值給cell的style屬性。
可以用的內置樣式有:
常規(guī):即沒有樣式,Normal。
數(shù)字樣式: Comma, Comma [0], Currency, Currency [0], Percent。
信息樣式: Calculation, Total, Warning Text, Explanatory Text。
文本樣式: Title, Headline 1, Headline 2, Headline 3, Headline 4, Hyperlink, Followed Hyperlink, Linked Cell。
比較樣式: Input, Output, Check Cell, Good, Bad, Neutral。
高亮樣式: Accent1, 20 % - Accent1, 40 % - Accent1, 60 % - Accent1, Accent2, 20 % - Accent2, 40 % - Accent2, 60 % - Accent2, Accent3, 20 % - Accent3, 40 % - Accent3, 60 % - Accent3, Accent4, 20 % - Accent4, 40 % - Accent4, 60 % - Accent4, Accent5, 20 % - Accent5, 40 % - Accent5, 60 % - Accent5, Accent6, 20 % - Accent6, 40 % - Accent6, 60 % - Accent6, Pandas。
提供的 樣式非常多,可以慢慢嘗試。
當然,也可以自定義樣式,利用前面介紹的方式定義好字體、對齊方式等,然后借助NamedStyle類,將前面設置的樣式傳入NamedStyle類中生成一個實例,然后賦值給cell的style屬性。受篇幅限制就不再詳細演示了。
fromopenpyxl.styles importNamedStyle
此外,也可以將前面設置好的各種樣式封裝到一個函數(shù)中,重復調用,與自定義樣式的效果異曲同工。
合并單元格
ws.cell(row= 5, column= 5).value = '秦'
ws.cell(row= 5, column= 6).value = 'A'
ws.cell(row= 5, column= 7).value = 'B'
ws.cell(row= 5, column= 8).value = 'W'
ws.cell(row= 6, column= 5).value = 'C'
ws.cell(row= 6, column= 6).value = 'D'
ws.cell(row= 6, column= 7).value = 'E'
ws.cell(row= 6, column= 8).value = 'W'
# 合并單元格
ws.merge_cells(start_row= 5, start_column= 5, end_row= 6, end_column= 7)
# ws.merge_cells(range_string='E5:G6')
效果:
在合并前,先在表格中寫入一些內容,然后對其中的部分單元格進行合并。
合并單元格使用ws.merge_cells方法,參數(shù)介紹:
start_row: 開始合并的行。
start_column: 開始合并的列。
end_row: 結束合并的行。
end_column: 結束合并的列。這四個值所在的行/列都會被合并(閉區(qū)間)。
range_string: 指定合并的單元格范圍,如E5:G6,第一個值是左上角的單元格,第二個值是右下角的單元格。 如果沒有設置range_string,則merge_cells會根據(jù)前四個參數(shù)自動計算出range_string。如果五個參數(shù)都設置了,則range_string會覆蓋前四個參數(shù)的設置。
合并單元格后,除了左上角的單元格的值保留,其他單元格的值都會被刪除,并且其他單元格都變成了只讀(read-only)單元格,不能寫入內容。
給合并后的單元格設置前文介紹的各種樣式時,字體、對齊方式、顏色填充用左上角的單元格設置,高寬按行列設置,邊框樣式要依次對每一個被合并的處于邊緣的單元格設置。
取消合并單元格
# 取消合并單元格
ws.unmerge_cells(start_row= 5, start_column= 5, end_row= 6, end_column= 7)
# ws.merge_cells(range_string='E5:G6')
效果:
取消合并單元格使用ws.unmerge_cells方法,參數(shù)與ws.merge_cells方法完全一樣。
取消合并后,合并單元格時被刪除的內容不能恢復,除了左上角的單元格,其他單元格的內容為空,可以重新寫入內容。
總結
本文完整總結了用Python設置Excel單元格樣式的知識,全是干貨,非常值得收藏。
文中用一個單元格做演示,實際使用時經(jīng)常需要批量操作,這個時候加個for循環(huán),改變cell中的row, column值,就可以批量處理了。批量處理的方法還有很多,可以因地制宜。
本文簡單易學,很多地方比官方文檔還詳細,希望對你有幫助,期待你的三連。
參考文檔:
[1] openpyxl官方文檔:https://openpyxl.readthedocs.io/en/stable/styles.html#cell-styles
自動化辦公我還是非常推薦下面這幾本書的,有需要的同學可以公眾號后臺咨詢小助手。公眾號:后臺輸入:小助手 ,暗號(自動化書).
入門: 最全的零基礎學Python的問題 | 零基礎學了8個月的Python |實戰(zhàn)項目 | 學Python就是這條捷徑
干貨:爬取豆瓣短評,電影《后來的我們》 | 38年NBA最佳球員分析 |從萬眾期待到口碑撲街!唐探3令人失望 | 笑看新倚天屠龍記 | 燈謎答題王 | 用Python做個海量小姐姐素描圖 | 碟中諜這么火,我用機器學習做個迷你推薦系統(tǒng)電影
趣味:彈球游戲 | 九宮格 | 漂亮的花 | 兩百行Python《天天酷跑》游戲!
AI:會做詩的機器人 | 給圖片上色 | 預測收入 | 碟中諜這么火,我用機器學習做個迷你推薦系統(tǒng)電影
小工具: Pdf轉Word,輕松搞定表格和水印! | 一鍵把html網(wǎng)頁保存為pdf! |再見PDF提取收費! | 用90行代碼打造最強PDF轉換器,word、PPT、excel、markdown、html一鍵轉換 | 制作一款釘釘?shù)蛢r機票提示器! |60行代碼做了一個語音壁紙切換器天天看小姐姐! |
年度爆款文案
1). 臥槽!Pdf轉Word用Python輕松搞定 !
2).學Python真香!我用100行代碼做了個網(wǎng)站,幫人PS旅行圖片,賺個雞腿吃
3).首播過億,火爆全網(wǎng),我分析了《乘風破浪的姐姐》,發(fā)現(xiàn)了這些秘密
4). 80行代碼!用Python做一個哆來A夢分身
5).你必須掌握的20個python代碼,短小精悍,用處無窮
6). 30個Python奇淫技巧集
7). 我總結的80頁《菜鳥學Python精選干貨.pdf》,都是干貨
8). 再見Python!我要學Go了!2500字深度分析 !
9).發(fā)現(xiàn)一個舔狗福利!這個Python爬蟲神器太爽了,自動下載妹子圖片
掃描二維碼推送至手機訪問。
版權聲明:本文由飛速云SEO網(wǎng)絡優(yōu)化推廣發(fā)布,如需轉載請注明出處。