Python-openpyxl教程11 - 注释和样式

前文:
Python-openpyxl教程5 - 与Pandas交互
Python-openpyxl教程6 - 图表之面积图和条形图
Python-openpyxl教程7 - 图表之散点图,饼图和环形图
Python-openpyxl教程8 - 图表之雷达图,股价图和曲面图图
Python-openpyxl教程9 - 轴使用之轴限制和比例
Python-openpyxl教程10 - 图表布局,填充图案以及进阶图表


注释

openpyxl当前仅支持读和写注释文本。

向单元格添加注释

注释具有text属性和author属性,必须同时设置它们。

from openpyxl import Workbook
from openpyxl.comments import Comment

wb = Workbook()
ws = wb.active

comment = ws['A1'].comment
comment = Comment('This is the comment text', 'Comment Author')
print(comment.text)
print(comment.author)

加载和保存评论

加载时工作薄中存在的注释会自动存储在其相应单元格的注释属性中。格式信息(如字体大小,粗体和斜体)以及注释的容器框的原始尺寸和位置都将丢失。

保存工作薄时保留在工作薄中的注释会自动保存到工作薄文件中

注释尺寸可以指定为只写。评论尺寸以像素为单位。

from openpyxl import Workbook
from openpyxl.comments import Comment
from openpyxl.utils import units

wb = Workbook()
ws = wb.active

comment = Comment('Text', 'Author')
comment.width = 300
comment.height = 50

ws['A1'].comment = comment

wb.save('SampleCommentedBook.xlsx')
SampleCommentBook

如果需要, openpyxl.utils.units包含用于从其他度量单位(例如mm或点)转换为像素的辅助函数:

from openpyxl import Workbook
from openpyxl.comments import Comment
from openpyxl.utils import units

wb = Workbook()
ws = wb.active

comment = Comment('Text', 'Author')
comment.width = units.points_to_pixels(300)
comment.height = units.points_to_pixels(50)

ws['A1'].comment = comment

使用样式

介绍

样式用于屏幕上显示时更改数据的外观。他们还用于确定数字的格式。

样式可以应用于以下方面:
- 用于设置字体大小,颜色,下划线等的字体
- 填充以设置图案或颜色渐变
- border可以设置单元格的边框
- 单元格对齐
- 保护

以下是默认值:

from openpyxl.styles import PatternFill, Border, Side, Alignment, Protection, Font

# 字体
font = Font(
    name='Calibri',  # 字体名称
    size=11,  # 字体大小
    bold=False,  # 字体加粗
    italic=False,  # 字体斜体
    vertAlign=None,  # 垂直对齐:'superscript', 'subscript', 'baseline'
    underline='none',  # 下划线
    strike=False,  # 删除线
    color='FF000000'  # 字体颜色
)

# 填充
fill = PatternFill(
    fill_type=None,
    # 填充类型:'mediumGray', 'lightDown', 'gray0625', 'lightGray', 'lightVertical', 'darkGray', 'darkVertical', 'gray125', 'darkDown', 'lightUp', 'darkHorizontal', 'solid', 'darkGrid', 'lightTrellis', 'lightGrid', 'darkTrellis', 'lightHorizontal', 'darkUp'
    start_color='FFFFFFFF',
    end_color='FF000000'
)

# 边框
border = Border(
    left=Side(border_style=None, color='FF000000'),
    # 线条边框样式:'dashed', 'thick', 'hair', 'thin', 'dashDotDot', 'mediumDashDot', 'medium', 'double', 'dotted', 'dashDot', 'mediumDashed', 'slantDashDot', 'mediumDashDotDot'
    right=Side(border_style=None, color='FF000000'),
    top=Side(border_style=None, color='FF000000'),
    bottom=Side(border_style=None, color='FF000000'),
    diagonal=Side(border_style=None, color='FF000000'),
    diagonal_direction=0,
    outline=Side(border_style=None, color='FF000000'),
    vertical=Side(border_style=None, color='FF000000'),
    horizontal=Side(border_style=None, color='FF000000')
)

# 对齐
alignment = Alignment(
    horizontal='general',
    # 水平对齐:'left', 'centerContinuous', 'fill', 'center', 'justify', 'distributed', 'right', 'general'
    textRotation=0,  # 文本旋转
    wrap_text=False,  # 文本环绕
    shrinkToFit=False,  # 缩小字体填充
    indent=0  # 文本缩进
)

# 数字格式,暂未找到使用方法
number_format = 'General'

# 保护
protection = Protection(locked=True, hidden=False)

单元格样式和命名样式

有两种类型的样式:单元样式和命名样式,也成为样式模板

单元格样式

单元格样式在对象之间共享,并且一旦分配了它们就无法更改。这样可以避免不必要的副作用,例如,仅更改一个单元格时就可以更改许多单元格的样式。

from openpyxl.styles import colors, Font, Color
from openpyxl import Workbook

wb = Workbook()
ws = wb.active

a1 = ws.cell(row=1, column=1)
d4 = ws.cell(row=4, column=4)
ft = Font(color='FF0000')
a1.font = ft
d4.font = ft

a1.font.italic = True

a1.font = Font(color='FF0000', italic=True)

复制样式

样式也可以复制

from openpyxl.styles import Font
from copy import copy

ft1 = Font(name='Arial', size=14)
ft2 = copy(ft1)
ft2.name = 'Tahoma'

print(ft1.name)  # Arial
print(ft2.name)  # Tahoma
print(ft1.size)  # 14.0
print(ft2.size)  # 14.0

颜色

字体,背景,边框等的颜色都可以通过三种方式设置:索引,aRGB或主题。 索引颜色是旧版实现,颜色本身取决于工作薄或应用程序默认提供的索引。主题颜色可用于互补色,但也取决于工作薄中存在的主题,因此,建议使用RGB颜色。

aRGB颜色

RGB颜色使用红色,绿色和蓝色的十六进制值设置

from openpyxl.styles import Font
font = Font(color='FF0000')

理论上,alpha值是指颜色的透明度,但这与单元格样式无关。默认值00将加在任何简单的RGB值之前:

from openpyxl.styles import Font

font = Font(color='00FF00')
print(font.color.rgb)

还支持传统索引颜色以及主题和色彩。

from openpyxl.styles.colors import Color

c = Color(indexed=32)
c = Color(theme=6, tint=0.5)

索引颜色

索引64和65不能设置,并且分别留给系统前景色和背景色


索引颜色

应用样式

样式直接应用于单元格

from openpyxl.workbook import Workbook
from openpyxl.styles import Font, fill

wb = Workbook()
ws = wb.active
cell1 = ws.cell(row=1, column=1)
cell1.font = Font(size=12)

样式也可以应用于行和列,但是请注意,这仅适用于关闭文件后再Excel中创建的单元格。如果要将样式应用于整个行和列,则必须自己将样式应用于每个单元格。这是文件格式的限制:

from openpyxl.workbook import Workbook
from openpyxl.styles import Font, fill

col = ws.cloumn_dimensions['A']
col.font = Font(bold=True)
row = ws.row_dimensions[1]
row.font = Font(underline='single')

样式化合并的单元格

合并的单元格的行为与其他单元格对象相似。其值和格式在其左上角的单元格中定义。为了更改整个合并单元格的边框。请更改其左上角单元格的边框。格式化是出于编写目的而生成的。

from openpyxl.styles import Border, Side, PatternFill, Font, GradientFill, Alignment
from openpyxl import Workbook

wb = Workbook()
ws = wb.active

ws.merge_cells('B2:F4')

top_left_cell = ws.cell(row=2, column=2)  # ws['B2']
top_left_cell.value = 'My Cell'

thin = Side(border_style='thin', color='000000')
double = Side(border_style='double', color='FF0000')

top_left_cell.border = Border(top=double, left=thin, right=thin, bottom=double)
top_left_cell.fill = PatternFill('solid', fgColor='DDDDDD')
top_left_cell.fill = fill = GradientFill(stop=('000000', 'FFFFFF'))
top_left_cell.font = Font(b=True, color='FF0000')
top_left_cell.alignment = Alignment(horizontal='center', vertical='center')

wb.save('SampleStyled.xlsx')

编辑页面设置

from openpyxl.workbook import Workbook

wb = Workbook()
ws = wb.active

ws.page_setup.orientation = ws.ORIENTATION_LANDSCAPE  # 纸张方向
ws.page_setup.paperSize = ws.PAPERSIZE_A4  # 纸张大小
ws.page_setup.fitToHeight = 0
ws.page_setup.fitToWidth = 1

命名样式

与单元格样式相反,命名样式是可变的。当您想一次将格式应用于许多不同的单元格时,它们很有意义。注意:将命名样式分配给单元格之后,对样式的其他更改将不会影响该单元格。

一旦将命名样式注册到工作薄中,就可以简单的通过名称来引用它。

创建命名样式

from openpyxl.styles import NamedStyle, Font, Border, Side

highlight = NamedStyle(name='highlight')
highlight.Font = Font(bold=True, size=20)
bd = Side(style='thick', color='000000')
highlight.border = Border(left=bd, top=bd, right=bd, bottom=bd)

创建命名样式后,可以将其注册到工作薄中:
wb.add_name_style(highlight)

但是,命名样式在首次分配给单元时也将自动注册:
ws['A1'].style = highlight

注册后,仅使用名称分配样式:
ws['D5'].style = 'highlight'

使用内置样式

该规范包括一些内置样式,也可以使用,不幸的是,这些样式的名称以本地化形式存储。
openpyxl仅会识别英文名称,并且只能与此处的文字完全一样。如下:

  • Normal # 和没有样式一样

Number formats

  • Comma
  • Comma[0]
  • Currency
  • Currency[0]
  • Percent

Informative

  • Calculation
  • Total
  • Note
  • Warning Text
  • Explanatory Text

Text Styles

  • Title
  • Headline 1
  • Headline 2
  • Headline 3
  • Headline 4
  • Hyperlink
  • Followed Hyperlink
  • Linked Cell

Comparisons

  • Input
  • Output
  • Check Cell
  • Good
  • Bad
  • Neutral

Highlights

  • 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

来源:
https://openpyxl.readthedocs.io/en/stable/comments.html
https://openpyxl.readthedocs.io/en/stable/styles.html

你可能感兴趣的:(Python-openpyxl教程11 - 注释和样式)