python替换word文件中的图片

python替换word文件中的图片

模拟鼠标键盘,截屏

python 复制代码
import glob
import os
import time

import pyautogui
import pyautogui as p
from PIL import ImageGrab
from pynput.keyboard import Controller

# -*- coding:utf-8 -*-


directory = './'

directory1 = './output'

for f in glob.glob(os.path.join(directory, '*.docx')):
    os.remove(f)

for f in glob.glob(os.path.join(directory1, '*.png')):
    os.remove(f)


def find_and_click(image_path, confidence):
    image_location = pyautogui.locateOnScreen(image_path, grayscale=True, confidence=confidence)
    if image_location:
        time.sleep(0.5)
        position = pyautogui.center(image_location)
        pyautogui.click(position)
    else:
        print(f"{image_path} 未找到指定的图片")


time.sleep(1)

# 初始化键盘控制器i
keyboard = Controller()

find_and_click("./images/01hf.jpg", 0.8)
time.sleep(1)

find_and_click("./images/02my.jpg", 0.8)
time.sleep(1)

find_and_click("./images/03bg.jpg", 0.8)
time.sleep(1)

find_and_click("./images/04cty.jpg", 0.8)
time.sleep(1)

find_and_click("./images/05zsxx.jpg", 0.8)
time.sleep(3)

find_and_click("./images/06sj.jpg", 0.8)
time.sleep(2)

find_and_click("./images/07ss.jpg", 0.8)
time.sleep(2)

keyboard = Controller()

keyboard.press(key='p')  # 按键按下s
time.sleep(0.2)
keyboard.release(key='p')  # 按键松开s
time.sleep(1)

find_and_click("./images/08sj.jpg", 0.8)
time.sleep(1)

p.doubleClick(1169, 145, 0.5)

time.sleep(5)

# 定义截图区域的左上角和右下角坐标
# 这里的坐标应根据你的需求进行调整
left, top, right, bottom = 992, 217, 1899, 391

# 使用ImageGrab.grab()方法进行截图
# 参数为截图区域的左上角和右下角坐标
screenshot = ImageGrab.grab(bbox=(left, top, right, bottom))

# 保存截图图片
screenshot.save('./output/0test.png')

time.sleep(0.5)
find_and_click("./images/14ht.jpg", 0.8)
time.sleep(3)

python替换word文件中的图片

python 复制代码
import glob
import os
import shutil
from docx import Document

# -*- coding:utf-8 -*-

# 删除目录下所有的*.docx文件
directory = './'

for f in glob.glob(os.path.join(directory, '*.docx')):
    os.remove(f)

# 将源文件拷贝到目标目录
source_file = 'D:\\周报整理\\2024年周报\\2024年4月运维服务报告v06.docx'
target_directory = './'
shutil.copy(source_file, target_directory)

# 获取目录下所有文件
folder_path = r'./'

file_list = os.listdir(folder_path)

# 遍历文件列表,修改xxx.docx改名为test.docx
for file_name in file_list:
    # 检查文件是否以 .xls 结尾
    if file_name.endswith('.docx'):
        # 构造新文件名
        new_file_name = os.path.join(folder_path, 'test.docx')
        # 重命名文件
        os.rename(os.path.join(folder_path, file_name), new_file_name)


def get_image_info(doc):
    for rel in doc.part.rels.values():
        if rel.reltype == 'http://schemas.openxmlformats.org/officeDocument/2006/relationships/image':
            print('Image ID:', rel.rId, 'Filename:', rel.target_part.filename)


def replace_image_by_id(doc, rId, new_image_path):
    for rel in doc.part.rels.values():
        if rel.reltype == 'http://schemas.openxmlformats.org/officeDocument/2006/relationships/image' and rel.rId == rId:
            target_part = rel.target_part
            with open(new_image_path, 'rb') as f:
                target_part._blob = f.read()


document = Document('test.docx')

# 获取图片信息
get_image_info(document)

# 替换图片
replace_image_by_id(document, 'rId11', './output/0test.png')


# 保存文档
document.save('output_test.docx')
相关推荐
财经资讯数据_灵砚智能10 分钟前
基于全球经济类多源新闻的NLP情感分析与数据可视化(日间)2026年6月6日
大数据·人工智能·python·ai·信息可视化·自然语言处理·灵砚智能
Land032921 分钟前
Python + RPA 双引擎实战:从手写脚本到可交付自动化应用的完整链路
python·自动化·rpa
菜到离谱但坚持41 分钟前
【小白零基础】RAG+LangChain 搭建私有知识库问答系统(完整可运行代码+超详细教程+避坑指南)
python·langchain·rag
知识的宝藏1 小时前
Xpaht self::div 轴语法
开发语言
keykey6.1 小时前
卷积神经网络(CNN):让AI学会“看“
开发语言·人工智能·深度学习·机器学习
ss2731 小时前
【入门OJ题解】分苹果问题(Python/Java/C 实现)
java·c语言·python
IsJunJianXin1 小时前
谷歌搜索cookie NID逆向生成
开发语言·python·google搜索·sgss·nid-cookie·算法生成nid·google-cookie
暗夜猎手-大魔王1 小时前
转载--Hermes Agent 11 | 智能审批与平台化安全:当 AI 来守护 AI
人工智能·python·安全
AIFQuant1 小时前
量化私募回测系统:高质量股票/外汇历史数据 API 选型与接入
python·websocket·金融·ai量化
Mr.Daozhi1 小时前
Playwright实战:抓取Meta Ad Library动态页面的三级降级策略
爬虫·python·自动化·playwright·meta广告