环境:Python3.6
本文主要是通过win32com操作word,对word中进行常用的操作。本文以替换为例,讲解一下如何使用Python在word中使用“通配符模式”(类似于正则表达式)替换文本内容。
#!/usr/bin/env python
# -*- coding:utf-8 -*-
import os
import win32com
from win32com.client import Dispatch
# 处理Word文档的类
class RemoteWord:
def __init__(self, filename=None):
self.xlApp = win32com.client.Dispatch(\'Word.Application\') # 此处使用的是Dispatch,原文中使用的DispatchEx会报错
self.xlApp.Visible = 0 # 后台运行,不显示
self.xlApp.DisplayAlerts = 0 #不警告
if filename:
self.filename = filename
if os.path.exists(self.filename):
self.doc = self.xlApp.Documents.Open(filename)
else:
self.doc = self.xlApp.Documents.Add() # 创建新的文档
self.doc.SaveAs(filename)
else:
self.doc = self.xlApp.Documents.Add()
self.filename = \'\'
def add_doc_end(self, string):
\'\'\'在文档末尾添加内容\'\'\'
rangee = self.doc.Range()
rangee.InsertAfter(\'\\n\' + string)
def add_doc_start(self, string):
\'\'\'在文档开头添加内容\'\'\'
rangee = self.doc.Range(0, 0)
rangee.InsertBefore(string + \'\\n\')
def insert_doc(self, insertPos, string):
\'\'\'在文档insertPos位置添加内容\'\'\'
rangee = self.doc.Range(0, insertPos)
if (insertPos == 0):
rangee.InsertAfter(string)
else:
rangee.InsertAfter(\'\\n\' + string)
def replace_doc(self, string, new_string):
\'\'\'替换文字\'\'\'
self.xlApp.Selection.Find.ClearFormatting()
self.xlApp.Selection.Find.Replacement.ClearFormatting()
#(string--搜索文本,
# True--区分大小写,
# True--完全匹配的单词,并非单词中的部分(全字匹配),
# True--使用通配符,
# True--同音,
# True--查找单词的各种形式,
# True--向文档尾部搜索,
# 1,
# True--带格式的文本,
# new_string--替换文本,
# 2--替换个数(全部替换)
self.xlApp.Selection.Find.Execute(string, False, False, False, False, False, True, 1, True, new_string, 2)
def replace_docs(self, string, new_string):
\'\'\'采用通配符匹配替换\'\'\'
self.xlApp.Selection.Find.ClearFormatting()
self.xlApp.Selection.Find.Replacement.ClearFormatting()
self.xlApp.Selection.Find.Execute(string, False, False, True, False, False, False, 1, False, new_string, 2)
def save(self):
\'\'\'保存文档\'\'\'
self.doc.Save()
def save_as(self, filename):
\'\'\'文档另存为\'\'\'
self.doc.SaveAs(filename)
def close(self):
\'\'\'保存文件、关闭文件\'\'\'
self.save()
self.xlApp.Documents.Close()
self.xlApp.Quit()
if __name__ == \'__main__\':
# path = \'E:\\\\XXX.docx\'
path = \'E:/XXX.docx\'
doc = RemoteWord(path) # 初始化一个doc对象
# 这里演示替换内容,其他功能自己按照上面类的功能按需使用
doc.replace_doc(\' \', \'\') # 替换文本内容
doc.replace_doc(\'.\', \'.\') # 替换.为.
doc.replace_doc(\'\\n\', \'\') # 去除空行
doc.replace_doc(\'o\',\'0\') # 替换o为0
# doc.replace_docs(\'([0-9])@[、,,]([0-9])@\', \'\\1.\\2\') 使用@不能识别改用{1,},\\需要使用反斜杠转义
doc.replace_docs(\'([0-9]){1,}[、,,.]([0-9]){1,}\', \'\\\\1.\\\\2\') # 将数字中间的,,、.替换成.
doc.replace_docs(\'([0-9]){1,}[旧]([0-9]){1,}\', \'\\\\101\\\\2\') # 将数字中间的“旧”替换成“01”
doc.close()
参考:https://www.cnblogs.com/zhuluqing/p/8445901.html
https://blog.csdn.net/baidu_39416074/article/details/80926443
继续阅读与本文标签相同的文章
下一篇 :
L0正则化实现原理分析
-
下载一款手机软件后,为何总是要让我们授权一些,看似毫无关联的权限?
2026-05-18栏目: 教程
-
千元机vivo Z5性能测试,妹子足够用
2026-05-18栏目: 教程
-
【从入门到放弃-ZooKeeper】ZooKeeper入门
2026-05-18栏目: 教程
-
105道BAT最新Java面试题(MySQL+Redis+nginx+ookeeper+MongoDB)
2026-05-18栏目: 教程
-
增值税发票管理系统2.0版即将上线啦
2026-05-18栏目: 教程
