openpyxl - 簡單設置單元格樣式

單元格樣式


簡介

openpyxl的單元格樣式由6種屬性決定,每一種都是一個類。如下所示(大概意思):

  • font(字體類):字號、字體顏色、下劃線等
  • fill(填充類):顏色等
  • border(邊框類):設置單元格邊框
  • alignment(位置類):對齊方式
  • number_format(格式類):數據格式
  • protection(保護類):寫保護
  • 單元格默認樣式如下:

    1. >>> from openpyxl.styles import PatternFill, Border, Side, Alignment, Protection, Font
    2. >>> font = Font(name='Calibri',
    3. ... size=11,
    4. ... bold=False,
    5. ... italic=False,
    6. ... vertAlign=None,
    7. ... underline='none',
    8. ... strike=False,
    9. ... color='FF000000')
    10. >>> fill = PatternFill(fill_type=None,
    11. ... start_color='FFFFFFFF',
    12. ... end_color='FF000000')
    13. >>> border = Border(left=Side(border_style=None,
    14. ... color='FF000000'),
    15. ... right=Side(border_style=None,
    16. ... color='FF000000'),
    17. ... top=Side(border_style=None,
    18. ... color='FF000000'),
    19. ... bottom=Side(border_style=None,
    20. ... color='FF000000'),
    21. ... diagonal=Side(border_style=None,
    22. ... color='FF000000'),
    23. ... diagonal_direction=0,
    24. ... outline=Side(border_style=None,
    25. ... color='FF000000'),
    26. ... vertical=Side(border_style=None,
    27. ... color='FF000000'),
    28. ... horizontal=Side(border_style=None,
    29. ... color='FF000000')
    30. ... )
    31. >>> alignment=Alignment(horizontal='general',
    32. ... vertical='bottom',
    33. ... text_rotation=0,
    34. ... wrap_text=False,
    35. ... shrink_to_fit=False,
    36. ... indent=0)
    37. >>> number_format = 'General'
    38. >>> protection = Protection(locked=True,
    39. ... hidden=False)
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28
    • 29
    • 30
    • 31
    • 32
    • 33
    • 34
    • 35
    • 36
    • 37
    • 38
    • 39

    以上幾種樣式(字體、填充、邊框、位置和保護)實例一旦被創建實例的屬性就不可更改,只能重新創建實例。

    1. >>> from openpyxl.styles import colors
    2. >>> from openpyxl.styles import Font, Color
    3. >>> from openpyxl.styles import colors
    4. >>> from openpyxl import Workbook
    5. >>> wb = Workbook()
    6. >>> ws = wb.active
    7. >>>
    8. >>> a1 = ws['A1']
    9. >>> d4 = ws['D4']
    10. >>> ft = Font(color=colors.RED)
    11. >>> a1.font = ft
    12. >>> d4.font = ft
    13. >>>
    14. >>> a1.font.italic = True # 不會生效,樣式實例一旦創建,實例的屬性就不可改變
    15. >>>
    16. >>> # 若要改變樣式,必須新建樣式實例
    17. >>>
    18. >>> a1.font = Font(color=colors.RED, italic=True) # 創建字體實例(紅色、斜體,其他屬性默認)

  • 複製樣式

    樣式可以被複制:

    1. >>> from openpyxl.styles import Font
    2. >>>
    3. >>> ft1 = Font(name='Arial', size=14)
    4. >>> ft2 = ft1.copy(name="Tahoma") # 複製時指定字體爲“Tahoma”,其他屬性均複製自ft1
    5. >>> ft1.name
    6. 'Arial'
    7. >>> ft2.name
    8. 'Tahoma'
    9. >>> ft2.size
    10. 14.0

    基本字體顏色

    字體顏色有一些顏色常量,可以直接調用:

    1. from openpyxl.styles import Font
    2. from openpyxl.styles.colors import RED
    3. font = Font(color=RED)
    4. font = Font(color="00FFBB00")
    • 1
    • 2
    • 3
    • 4

    也可以按索引創建實例:

    1. from openpyxl.styles.colors import Color
    2. c = Color(indexed=32)
    3. c = Color(theme=6, tint=0.5)
    • 1
    • 2
    • 3

    說到顏色,V2.3.5版本必須使用“00XXXXXX”的格式,不能使用“#XXXXXX”的格式。如果顏色不生效請查看版本後修改。

    應用樣式

    可以直接應用到單元格:

    1. from openpyxl.workbook import Workbook
    2. from openpyxl.styles import Font, Fill
    3. wb = Workbook()
    4. ws = wb.active
    5. c = ws['A1']
    6. c.font = Font(size=12)
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6

    可以對整行整列設置樣式,前提是單元格已創建。

    1. col = ws.column_dimensions['A']
    2. col.font = Font(bold=True)
    3. row = ws.row_dimensions[1]
    4. row.font = Font(underline="single")

    數據格式

    數據格式屬性number_format的值是字符串類型,不爲對象,直接賦值即可。 
    openpyxl內置了一些數據格式查看openpyxl.styles.numbers,也支持excel自定義格式,以下兩種方式效果相同:

    1. # 使用openpyxl內置的格式
    2. from openpyxl.styles import numbers
    3. ws.cell['D2'].number_format = numbers.FORMAT_GENERAL
    4. ws.cell(row=2, column=4).number_format = numbers.FORMAT_DATE_XLSX15
    • 1
    • 2
    • 3
    • 4
    1. # 直接使用字符串
    2. ws.cell['D2].number_format = 'General'
    3. ws.cell(row=2, column=4).number_format = 'd-mmm-yy'
    • 1
    • 2
    • 3

    編輯頁面設置

    1. from openpyxl.workbook import Workbook
    2. wb = Workbook()
    3. ws = wb.active
    4. ws.page_setup.orientation = ws.ORIENTATION_LANDSCAPE
    5. ws.page_setup.paperSize = ws.PAPERSIZE_TABLOID
    6. ws.page_setup.fitToHeight = 0
    7. ws.page_setup.fitToWidth = 1
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9

    編輯打印選項

    1. from openpyxl.workbook import Workbook
    2. wb = Workbook()
    3. ws = wb.active
    4. ws.print_options.horizontalCentered = True
    5. ws.print_options.verticalCentered = True

發佈了18 篇原創文章 · 獲贊 9 · 訪問量 1萬+
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章