如何解决编写一个 for 循环来创建单独的 docx 文件,因为它使用 python-docx 模块进行迭代?
当我运行我的脚本时,它能够创建文档并添加指定的文本就好了。 值得注意的是,我添加到文档中的文本是从 html 解析的工作列表。 接下来我要考虑的是如何拥有它,以便当我运行我的脚本时,它将遍历每个列表,并为每个相应的列表创建一个单独的 docx 文件。 我尝试将 document = Document() 写入 for 循环,但这似乎不起作用,因为它只为第一个列表创建了一个文档。这甚至可能吗?
class EnumSynonymMixin:
"""
Enum mixin which provides the ability to define synonyms,ie. values which can be passed into an enum's constructor,that
name the same member as one of the defined values,without adding
any extra members (useful for using with sqlAlchemy's Enum mapping)
For example:
class MyEnum(EnumSynonymMixin,enum.Enum):
FOO = "FOO"
BAR = "BAR"
@classmethod
def synonyms(cls):
return {"MYFOO": "FOO"}
>>> MyEnum("MYFOO")
<MyEnum.FOO: 'FOO'>
"""
@classmethod
def synonyms(cls):
"""Override to provide a dictionary of synonyms for values that can be
passed to the constructor"""
return {}
@classmethod
def _missing_(cls,val):
synonyms = cls.synonyms()
if val in synonyms:
return cls.__members__[synonyms[val]]
return super()._missing(val)
class TrainOutcome(EnumSynonymMixin,enum.Enum):
PASSED = "PASSED"
Failed = "Failed"
STARTED = "STARTED"
@classmethod
def synonyms(cls):
return {"SUCCESS": "PASSED"}
解决方法
您的文档始终具有相同的名称,因此在循环的每次迭代中您都会覆盖前一个文件。 quickfix 将是:document.save(f'{idx}_wordy.docx')
并且 document = document 应该在循环内。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。