批量替换word内容

Posted mrwuzs

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了批量替换word内容相关的知识,希望对你有一定的参考价值。

有一个需求需要把word中的一段文档的编号批量替换

技术图片

如,把133-183批量的替换成31-81,需要批量的替换word,脚本如下

from docx import Document
import os

oldFile = "C:\\Users\\wuzs\\Desktop\\test.docx"
newFile = "C:\\Users\\wuzs\\Desktop\\test2.docx"

DICT = 
"SP_OS_NETWORK_133":"SP_OS_NETWORK_031",
"SP_OS_NETWORK_134":"SP_OS_NETWORK_032",
"SP_OS_NETWORK_135":"SP_OS_NETWORK_033",
"SP_OS_NETWORK_136":"SP_OS_NETWORK_034",
*****************

*****************
"SP_OS_NETWORK_182":"SP_OS_NETWORK_080",
"SP_OS_NETWORK_183":"SP_OS_NETWORK_081",




def main():
    document = Document(oldFile)
    document = check(document)
    document.save(newFile)


def check(document):
    # tables
    for table in document.tables:
        for row in range(len(table.rows)):
            for col in range(len(table.columns)):
                for key, value in DICT.items():
                    if key in table.cell(row, col).text:
                        print(key + "->" + value)
                        table.cell(row, col).text = table.cell(row, col).text.replace(key, value)

    # paragraphs
    for para in document.paragraphs:
        for i in range(len(para.runs)):
            for key, value in DICT.items():
                if key in para.runs[i].text:
                    print(key + "->" + value)
                    para.runs[i].text = para.runs[i].text.replace(key, value)

    return document


if __name__ == '__main__':
    main()

以上是关于批量替换word内容的主要内容,如果未能解决你的问题,请参考以下文章

批量替换word内容

如何用VBA实现WORD批量替换?

不打开WORD文档批量替换文档内容

notepad++如何批量将分隔符前面的内容替换为分隔符后面的内容

SQl Server 2005怎么批量替换用户名

怎样在word中批量替换文字?Word替换文字这一招你会吗?