python-docx官方文档翻译--用户指南09--使用样式

使用样式

本页面使用上一页中开发的概念,无需介绍。如果不熟悉该术语,请查阅上一页 了解样式 中的定义。

访问样式

使用 Document.styles 属性访问样式:

document = Document()
styles = document.styles
styles
# <docx.styles.styles.Styles object at 0x10a7c4f50>

Styles 对象提供按名称对定义的样式的字典式访问:

styles['Normal']
# <docx.styles.style._ParagraphStyle object at <0x10a7c4f6b>

注意

内置样式以其英文名称的方式存储在 WordprocessingML 文件中,例如 “Heading 1”,即使使用 Word 的本地化版本的用户也会在用户界面中看到母语名称,例如 “ 标题 1”。由于 python-docx 在 WordprocessingML 文件上运行,因此样式查找必须使用英文名称。该外部站点上的文档可让您在本地语言名称和英语样式名称之间创建映射:
http://www.thedoctools.com/index.php?show=mt_create_style_name_list
现链接为:https://www.thedoctools.com/word-macros-tips/word-macros/create-style-name-list/
ps: 好像只有 英语,丹麦语,德语和法语

用户定义的样式(也称为自定义样式)未本地化,并且使用与 Word UI 中显示的名称完全相同的名称进行访问。

Styles 对象也是可迭代的。通过使用 BaseStyle 上的标识属性,可以生成已定义样式的各种子集。例如,此代码将生成已定义的段落样式的列表:

from docx.enum.style import WD_STYLE_TYPE
styles = document.styles
paragraph_styles = [
    s for s in styles if s.type == WD_STYLE_TYPE.PARAGRAPH
]
for style in paragraph_styles:
    print(style.name)
# Normal
# Body Text
# List Bullet

应用样式

ParagraphRunTable 对象每个都有一个 style 属性。将样式对象分配给此属性将应用该样式:

document = Document()
paragraph = document.add_paragraph()
paragraph.style
# <docx.styles.style._ParagraphStyle object at <0x11a7c4c50>
paragraph.style.name
# 'Normal'
paragraph.style = document.styles['Heading 1']
paragraph.style.name
# 'Heading 1'

样式名称也可以直接分配,在这种情况下,python-docx将执行查找:

paragraph.style = 'List Bullet'
paragraph.style
# <docx.styles.style._ParagraphStyle object at <0x10a7c4f84>
paragraph.style.name
# 'List Bullet'

也可以在创建时使用样式对象或其名称来应用样式:

paragraph = document.add_paragraph(style='Body Text')
paragraph.style.name
# 'Body Text'
body_text_style = document.styles['Body Text']
paragraph = document.add_paragraph(style=body_text_style)
paragraph.style.name
# 'Body Text'

添加或删除样式

通过指定唯一名称和样式类型,可以将新样式添加到文档中:

from docx.enum.style import WD_STYLE_TYPE
styles = document.styles
style = styles.add_style('Citation', WD_STYLE_TYPE.PARAGRAPH)
style.name
# 'Citation'
style.type
# PARAGRAPH (1)

使用 base_style 属性指定新样式应继承的格式:

style.base_style
# None
style.base_style = styles['Normal']
style.base_style
# <docx.styles.style._ParagraphStyle object at 0x10a7a9550>
style.base_style.name
# 'Normal'

只需调用样式的 delete() 方法即可将样式从文档中删除:

styles = document.styles
len(styles)
# 10
styles['Citation'].delete()
len(styles)
# 9

注意

Style.delete() 方法从文档中删除样式的定义。它不会影响应用该样式的文档中的内容。文档中未定义样式的内容以默认样式进行呈现。如果是段落,则为“Normal”。

定义字符格式

字符,段落和表格样式都可以指定要应用于该样式内容的字符格式。所有字符格式可以用样式指定也可以直接应用于文本。示例包括字体字体和大小,粗体,斜体和下划线。

这三种样式类型中的每一种都有一个 font 属性,该属性提供对 Font 对象的访问。样式的 Font 对象提供用于获取和设置该样式的字符格式的属性。

这里提供了几个示例。有关可用属性的完整集合,请参见 Font API 文档。

样式的字体可以这样访问:

from docx import Document
document = Document()
style = document.styles['Normal']
font = style.font

字体和大小设置如下:

from docx.shared import Pt
font.name = 'Calibri'
font.size = Pt(12)

许多字体属性是三态的,这意味着它们可以采用值 True,False 和 None。True 表示属性为“ on”,False 表示属性为“ off”。从概念上讲,None 值表示“继承”。因为样式存在于继承层次结构中,所以重要的是具有在层次结构中正确位置指定属性的能力,通常在层次结构中尽可能远。例如,如果所有标题都应为 Arial 字体,则在 Heading 1 样式上设置该属性并使 Heading 2 继承自 Heading 1 更为有意义。

粗体和斜体是三态属性,全大写,删除线,上标和其他许多属性也是如此。有关完整列表,请参见 Font API文档。

font.bold, font.italic
# (None, None)
font.italic = True
font.italic
# True
font.italic = False
font.italic
# False
font.italic = None
font.italic
# None

下划线有点特殊情况。它是三态属性和枚举值属性的混合。 True 表示单下划线,是迄今为止最常见的下划线。 False 表示没有下划线,但是如果不需要下划线,则通常 None 是正确的选择,因为很少从基础样式继承下划线。用 WD_UNDERLINE 枚举的成员指定其他形式的下划线,例如双下划线或虚线。

font.underline
# None
font.underline = True
# 或
font.underline = WD_UNDERLINE.DOT_DASH

定义段落格式

段落样式和表格样式都允许指定段落格式。这些样式通过它们的 paragraph_format 属性提供对 ParagraphFormat 对象的访问。

段落格式包括布局行为,例如对齐,缩进,前后的空间,分页符之前的行为以及 widow_control。有关可用属性的完整列表,请查阅API文档页面中的 ParagraphFormat 对象。

以下示例,说明如何创建具有 1/4 英寸的悬挂缩进,上方 12 Pt的间距以及 widow_control 的段落样式:

from docx.enum.style import WD_STYLE_TYPE
from docx.shared import Inches, Pt
document = Document()
style = document.styles.add_style('Indent', WD_STYLE_TYPE.PARAGRAPH)
paragraph_format = style.paragraph_format
paragraph_format.left_indent = Inches(0.25)
paragraph_format.first_line_indent = Inches(-0.25)
paragraph_format.space_before = Pt(12)
paragraph_format.widow_control = True

使用段落特定的样式属性

段落样式具有 next_paragraph_style 属性,该属性指定要应用于在该样式的段落之后插入的新段落的样式。当样式通常仅在序列(例如标题)中仅出现一次时,这非常有用。在这种情况下,可以在完成标题后将段落样式自动设置回正文样式。

在最常见的情况下(正文段落),后续段落应采用与当前段落相同的样式。如果未指定下一个段落样式,则默认值可以通过应用相同的样式来很好地处理这种情况。

以下示例说明了如何将 Heading 1 样式的下一个段落样式更改为正文。

from docx import Document
document = Document()
styles = document.styles
styles['Heading 1'].next_paragraph_style = styles['Body Text']

可以通过分配 None 或样式本身来恢复默认行为:

heading_1_style = styles['Heading 1']
heading_1_style.next_paragraph_style.name
# 'Body Text'

heading_1_style.next_paragraph_style = heading_1_style
heading_1_style.next_paragraph_style.name
# 'Heading 1'

heading_1_style.next_paragraph_style = None
heading_1_style.next_paragraph_style.name
# 'Heading 1'

控制样式在Word UI中的显示方式

样式的属性分为两类,行为属性和格式设置属性。行为属性控制样式在 Word UI 中显示的时间和位置。格式属性决定了要应用样式的内容的格式,例如字体的大小及其段落缩进。

样式有五个行为属性:

请参阅 “了解样式”中的“样式特性” 部分,以获取有关这些行为属性如何相互作用以确定样式在 Word UI 中何时何地出现的描述。

priority 属性采用整数值。其他四个样式行为属性是三态的,这意味着它们可以采用值 True(打开),False(关闭)或None(继承)。

在样式库中显示样式

以下代码将使“Body Text(正文)”段落样式首先出现在样式库中:

from docx import Document
document = Document()
style = document.styles['Body Text']

style.hidden = False
style.quick_style = True
style.priorty = 1

从样式库中删除样式

此代码将从样式库中删除“Normal(普通)”段落样式,但允许其保留在建议的列表中:

style = document.styles['Normal']

style.hidden = False
style.quick_style = False

处理潜在样式

有关潜在样式如何定义尚未在 .docx 文件的 styles.xml part 中定义的内置样式的行为属性的描述,请参阅“了解样式”中的“内置样式和潜在样式”部分。

访问文档中的潜在样式

可从样式对象访问文档中的潜在样式:

document = Document()
latent_styles = document.styles.latent_styles

LatentStyles 对象支持 len(),迭代和以字典形式通过样式名称访问:

len(latent_styles)
# 161

latent_style_names = [ls.name for ls in latent_styles]
latent_style_names
# ['Normal', 'Heading 1', 'Heading 2', ... 'TOC Heading']

latent_quote = latent_styles['Quote']
latent_quote
# <docx.styles.latent.LatentStyle object at 0x10a7c4f50>
latent_quote.priority
# 29
更改默认样式

LatentStyles 对象还提供对当前文档中内置样式的默认行为属性的访问。这些默认值为 _LatentStyle 定义的任何未定义属性以及没有显式潜在样式定义的内置样式的所有行为属性提供值。有关可用属性的完整集合,请参见 LatentStyles 对象的API文档:

latent_styles.default_to_locked
# False
latent_styles.default_to_locked = True
latent_styles.default_to_locked
# True
添加潜在样式定义

可以使用 LatentStyles 上的 add_latent_style() 方法添加新的潜在样式。这段代码为内置样式“List Bullet(列表项目符号)”添加了新的潜在样式,并将其设置为显示在样式库中:

latent_style = latent_styles['List Bullet']
# KeyError: no latent style with name 'List Bullet'
latent_style = latent_styles.add_latent_style('List Bullet')
latent_style.hidden = False
latent_style.priority = 2
latent_style.quick_style = True
删除潜在样式定义

潜在样式定义可以通过调用其 delete() 方法来删除:

latent_styles['Light Grid']
# <docx.styles.latent.LatentStyle object at 0x10a7c4f50>
latent_styles['Light Grid'].delete()
latent_styles['Light Grid']
# KeyError: no latent style with name 'Light Grid'
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,723评论 6 498
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,003评论 3 391
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,512评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,825评论 1 290
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,874评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,841评论 1 295
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,812评论 3 416
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,582评论 0 271
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,033评论 1 308
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,309评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,450评论 1 345
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,158评论 5 341
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,789评论 3 325
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,409评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,609评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,440评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,357评论 2 352