Python读取word中的图片并按照一定顺序进行命名

图片命名顺序在一张excel的第一列
先爬取word中的所有图片
接着创建图片序列名称字段
遍历文件夹中的图片进行重命名

import docx
import os, re
import xlwt
import openpyxl
from openpyxl import Workbook, workbook
from openpyxl import load_workbook
import zipfile
import shutil

# 读取命名前缀到nameex
wb = load_workbook('图片顺序.xlsx')
ws = wb['Sheet1']  # sheet名称
sheet = wb.active
a = sheet.max_row
nameex = []
i = 0
while i < a:
    i = i + 1
    nameex.insert(i, ws.cell(i, 1).value)
nameend = ['001', '002', '003', '004']

doc_path = 'word_path/test.docx'   #在这里更换你想要的路径
img_path = 'allpictures/'  #在这里更换你想要的路径

os.makedirs(img_path, exist_ok=True)

doc = zipfile.ZipFile(doc_path)

img_list=[]
img_list_error=[]

for info in doc.infolist():
       if info.filename.endswith((".png", ".jpeg", ".gif")):
           doc.extract(info.filename, img_path)
           img_list_error.append(info.filename)

print(img_list_error)

path1 = "allpictures/word/media"
filelist1 = os.listdir(path1)
total_num = len(filelist1)

for m in range(total_num+1):
    image_name="image"+str(m)+".jpeg"
    img_list.append(image_name)

print(img_list)

path = r"allpictures\word\media"

j = 0
k = 0
for item in img_list:
    if item.endswith('.jpeg'):

        project_name = nameex[j]
        fid = nameend[k]
        img_name = f'{project_name}_{fid}.jpeg'

        src = os.path.join(os.path.abspath(path), item)
        dst = os.path.join(os.path.abspath(path), img_name)
        try:
            os.rename(src, dst)
            k = k + 1
            if (k > 3):
                k = 0
                j = j + 1
        except:
            print(project_name)
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Yokon_D

您的鼓励将是我最大的动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值