用python提取word中的所有图片

        使用word中提取的方式图片会丢失清晰度,使用python写一个脚本,程序运行将弹出对话框选择一个word文件,然后在弹出一个对话框选择一个文件夹保存word中的文件。将该word中的所有图片都保存成png格式,并命名成image_i的样式。

程序运行步骤如下图所示:

代码:

其中,save_images_from_word函数介绍如下:

  • docx_file:一个字符串,表示要处理的Word文档的路径。
  • output_folder:一个字符串,表示要将图片保存到的文件夹路径。
  1. 使用python-docx库打开给定的Word文档,并将其内容存储在doc对象中。
  2. for i, rel in enumerate(doc.part.rels.values())::遍历文档中的所有关系。每一个关系rel都代表文档中的一个链接或嵌入的对象。通过enumerate函数,我们可以同时获得关系的索引i和关系对象本身。
  3. if "image" in rel.reltype:
    检查当前的关系是否是一个图片。rel.reltype是一个字符串,表示关系的类型。如果这个字符串中包含"image",则表示这是一个图片关系。
  4. image_bytes = rel.target_part.blob
    从图片关系中获取图片的原始字节数据。这里,rel.target_part.blob表示图片的原始二进制数据。
  5. with open(os.path.join(output_folder, f"image_{i}.png"), "wb") as f:
    使用os.path.join函数构造保存图片的完整路径。这里使用了格式化字符串(f-string),将关系索引转换为"image_{i}.png"这样的文件名。例如,如果索引是0,则文件名为"image_0.png"。
  6. f.write(image_bytes)
    将图片的原始字节数据写入到刚刚打开的文件中。这样,图片就被保存为PNG格式的文件了。
##########################################
#选择一个word文件,在选择一个路径
#程序将所有word中的图片保存成png格式,
#并且命名为image_i

from tkinter import Tk, filedialog  
from docx import Document  
import os  
import io
#from docx.shapes.picture import Picture
from PIL import Image  
  
def save_images_from_word(docx_file, output_folder):
    doc = Document(docx_file)
    for i, rel in enumerate(doc.part.rels.values()):
        if "image" in rel.reltype:
            image_bytes = rel.target_part.blob
            with open(os.path.join(output_folder, f"image_{i}.png"), "wb") as f:
                f.write(image_bytes)  
def select_file():  
    root = Tk()  
    root.withdraw()  
    file_path = filedialog.askopenfilename(filetypes=[("Word files", "*.docx")])  
    return file_path  
  
def select_output_folder():  
    root = Tk()  
    root.withdraw()  
    output_folder = filedialog.askdirectory()  
    return output_folder  
  
# 选择Word文件  
file_path = select_file()  
if file_path:  
    # 选择输出文件夹  
    output_folder = select_output_folder()  
    if output_folder:  
        # 保存图片到输出文件夹  
        save_images_from_word(file_path, output_folder)

相关推荐

  1. python实现提取word所有图片

    2024-01-06 11:04:04       36 阅读
  2. python实现word所有图片变清晰

    2024-01-06 11:04:04       36 阅读
  3. python替换word文件图片

    2024-01-06 11:04:04       6 阅读
  4. Python和VBA批量提取Word表格

    2024-01-06 11:04:04       31 阅读
  5. python如何提取html所有中文

    2024-01-06 11:04:04       8 阅读

最近更新

  1. TCP协议是安全的吗?

    2024-01-06 11:04:04       16 阅读
  2. 阿里云服务器执行yum,一直下载docker-ce-stable失败

    2024-01-06 11:04:04       16 阅读
  3. 【Python教程】压缩PDF文件大小

    2024-01-06 11:04:04       15 阅读
  4. 通过文章id递归查询所有评论(xml)

    2024-01-06 11:04:04       18 阅读

热门阅读

  1. 实现3x3卷积的手写FIFO

    2024-01-06 11:04:04       34 阅读
  2. [数据结构]链栈的创建,入栈和出栈

    2024-01-06 11:04:04       30 阅读
  3. vue3防抖函数封装与使用,以指令的形式使用

    2024-01-06 11:04:04       34 阅读
  4. 使用 openpyxl 库读取 Excel 文件

    2024-01-06 11:04:04       35 阅读
  5. MySQL-DDL

    MySQL-DDL

    2024-01-06 11:04:04      26 阅读