python实现表格批量url替换成图片

python实现表格批量url替换成图片

  • 在网上找了一圈,看着大家写的都挺好,就是拿过来在自己的电脑上运行报错,然后经过了一定的加工,跑通整个代码。至于没成功的,我们可以在excel中重新整理,数量如果大于10个我们就再排量跑一圈,如果少了就自己手动一下,我们主打的就是批量,给大家节约时间。当然大佬自己搂代码。
 

from csv import excel
import io
import requests
import time
import re
from openpyxl import load_workbook
from openpyxl.drawing.image import Image
 

# 保持图片的比例
def img_resize(width, height):
    if width > height:
        height = height*200//width
        width = 200
    else:
        width = width*200//height
        height = 200
    return width, height
# 获得选中的表的最大行数和最大列数
def getRowsClosNum(self):
        rows = self.max_row
        columns = self.max_column
        return rows,columns

def get_row_value(self, row):
        columns = self.max_column
        row_data = []
        for i in range(1, columns + 1):
            cell_value = self.cell(row=row, column=i).value
            row_data.append(cell_value)
        return row_data


def urlpoint(data):
    NumTip = []
    if data == []:
        return -1
    for i in range(len(data)):
        strname =str(data[i])
         # 用于匹配至少一个图片形式
        pattern = re.compile(r'(.png|.img|.gif|.jpg|.jpeg)$')    
        m = pattern.search(strname)
        if m == None:
            continue
        else:
            NumTip.append(i)
    # 如果一个图片地址都没有找到就返回-1,不然返回下表的集合
    if  NumTip == []:
        return -1
    else:
        return NumTip

def TurnURLPictures():
    ExcleSheet=0
    start = time.time()
    # 用户下载的位置
    textname ='请求图片 - 副本下载.xlsx'
    # 用户上传的位置
    dataname ='请求图片 - 副本.xlsx'
    wb = load_workbook(dataname)
    Sheetnames =wb.sheetnames
    #默认是第一个表
    ws = wb[Sheetnames[ExcleSheet]]
    # 获得第二行的数据,通常来说第一行是标题名,带入get_row_value()里面,
    cData = get_row_value(ws,1)
    #得到这个表的行高
    Crows,Ccolumns= getRowsClosNum(ws)
    #url 所在列
    urlnum =urlpoint(cData)
    if urlnum == -1:
        print ('Its second line does not have a URL')
        return  -1
    #拼接操作的xlsx 文件的行数 一般为2-maxrow   
    Cnum ={1:"A",2:"B",3:"C",4:"D",5:"E",6:"F",7:"G",8:"H",9:"I",10:"J",11:"K",12:"L",13:"M",14:"N","15":"O",16:"P",17:"Q",18:"R",19:"S",20:"T",21:"U",22:"V",23:"W",24:"X",25:"Y"}
    # 
    GroupNum = len(urlnum)
    for  i in range(GroupNum):
        subscript = urlnum[i]+1

        name =str(Cnum[subscript])+'2:'+str(Cnum[subscript])+str(Crows)

        ws.column_dimensions[Cnum[subscript]].width = 50

        for cell, in ws[name]:
            
            try:
            
                url = cell.value
                 #阻止某些为空
                if url == None:


                    continue
                #事实上这里可以检查一下url是否有前缀http 这样可以兼容一下其他形式的图片
                pattern = re.compile(r'^(https://|http://)')     
                   # 用于匹配至少一个数字
                m = pattern.match(url)


                if m == None:


                    url ='https://image.baidu.com/' +url
                 # 删除超链接

                cell.hyperlink = None
                # # 删除内容
                cell.value = ""
                # 设置行高
                ws.row_dimensions[cell.row].height = 200
                 # 下载图片到内存
                res = requests.get(url)


                img = Image(io.BytesIO(res.content))
                # 等比例缩放图片
                width, height = img_resize(img.width, img.height)


                img.width = width


                img.height = height
                # 拼接目标单元格   subscript 是替换url     Ccolumns+i+1 是按顺序放后面
                endnum =str(Cnum[subscript]) + str(cell.row)


                print('成功添加到第:',endnum,'列')
                 # 添加图片到指定单元格
                ws.add_image(img, endnum)
                
            except:
                pass
    start2 = time.time()
    wb.save(textname)
    print('Running time: %s 毫秒' % (start2*1000-start*1000))
    return Crows/60
    



if __name__=="__main__":
    TurnURLPictures()

在这里插入图片描述

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论
可以使用Python的os和shutil模块来批量修改和替换图片文件名称。 具体步骤如下: 1. 导入os和shutil模块 ```python import os import shutil ``` 2. 遍历指定目录下的所有文件 ```python path = './images' # 指定目录 for filename in os.listdir(path): filepath = os.path.join(path, filename) # 获取文件路径 if os.path.isfile(filepath): # 判断是否为文件 # 对文件进行操作 ``` 3. 修改文件名称 使用os模块的rename方法可以修改文件名称。可以根据需要对文件名称进行处理,如添加前缀、后缀或替换特定字符。 ```python new_filename = 'new_' + filename # 添加前缀 new_filepath = os.path.join(path, new_filename) # 新文件路径 os.rename(filepath, new_filepath) # 修改文件名称 ``` 4. 替换文件名称 如果需要替换特定字符,可以使用Python的字符串替换函数replace()。 ```python new_filename = filename.replace('old', 'new') # 替换字符 new_filepath = os.path.join(path, new_filename) # 新文件路径 os.rename(filepath, new_filepath) # 修改文件名称 ``` 完整代码示例: ```python import os import shutil path = './images' # 指定目录 for filename in os.listdir(path): filepath = os.path.join(path, filename) # 获取文件路径 if os.path.isfile(filepath): # 判断是否为文件 new_filename = filename.replace('old', 'new') # 替换字符 new_filepath = os.path.join(path, new_filename) # 新文件路径 os.rename(filepath, new_filepath) # 修改文件名称 ``` 这样就可以批量修改和替换指定目录下的图片文件名称。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

大数据采集及分析RPA

你的鼓励将是我创作的最大动力

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

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

打赏作者

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

抵扣说明:

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

余额充值