作者热门文章
- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我想使用 python-pptx 模块来更改给定 powerpoint 演示文稿中每个包含文本的形状的校对语言。
不幸的是,我没有管理。 :(
我正在使用 Python 3.6.3 和 python-pptx 0.6.7。
我的代码如下所示:
from pptx import Presentation
from pptx.enum.lang import MSO_LANGUAGE_ID
# In this example code, all proofing language is set to ENGLISH_UK
# all languages can be found in the docs for python-pptx
new_language = MSO_LANGUAGE_ID.ENGLISH_UK
input_file = 'test_pptx.pptx'
output_file = input_file[:-5] + '_modified.pptx'
# Open the presentation
prs = Presentation(input_file)
# iterate through all slides
for slide_no, slide in enumerate(prs.slides):
# iterate through all shapes/objects on one slide
for shape in slide.shapes:
# check if the shape/object has text (pictures e.g. don't have text)
if shape.has_text_frame:
# print some output to the console for now
print('SLIDE NO# ', slide_no + 1)
print('Object-Name: ', shape.name)
print('Text -->', shape.text)
# check for each paragraph of text for the actual shape/object
for paragraph in shape.text_frame.paragraphs:
for run in paragraph.runs:
# display the current language
print('Actual set language: ', run.font.language_id)
# set the 'new_language'
run.font.language_id = new_language
else:
print('SLIDE NO# ', slide_no + 1, ': This object "', shape.name, '" has no text.')
print(' +++++ next element +++++ ')
print('--------- next slide ---------')
# save pptx with new filename
prs.save(output_file)
最佳答案
我实际上并不完全确定校对功能决定使用哪个字典的所有规则,但语言是在运行级别设置的,我认为这是一个很好的起点。
这在一定程度上是有道理的,因为您可以在一段文本中间有一个外来短语,而只有形状级别的语言设置是不支持的。
因此,一旦通过 .has_text_frame
,就需要一些额外的代码。测试:
for paragraph in shape.text_frame.paragraphs:
for run in paragraph.runs:
font = run.font
print(font.language_id)
TURKISH (1055)
ENGLISH_UK (2057)
...
.xml_value
上提供的标准语言代码提供了一些附加信息。属性,因此您可以将输出详细说明为:
for run in paragraph.runs:
font = run.font
language_id = font.language_id
print('\'%s\'' % run.text, language_id, language_id.xml_value)
'the rain in ' ENGLISH_US (1033) en-US
'España' SPANISH (1034) es-ES_tradnl
...
关于python-pptx - 设置校对语言,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/47059757/
H2 数据库可以使用哪种排序规则,既不忽略空格,又同时识别带变音符号和不带变音符号的字符? 例如,应将“Ilkka Seppälä”和“Ilkka Seppala”视为相同。它还需要将“MSaifAs
我是一名优秀的程序员,十分优秀!