import os
import time
import psutil
from selenium.webdriver.chrome.options import Options
from selenium import webdriver
from selenium.webdriver.common.by import By
import openpyxl
import requests

# 检查是否已经存在浏览器实例,如果存在则不再创建
for proc in psutil.process_iter():
    try:
        if 'chrome' in proc.name() and '--remote-debugging-port=9224' in proc.cmdline():
            options = Options()
            options.add_experimental_option('debuggerAddress', '127.0.0.1:9224')
            break
    except:
        pass
else:
    # 创建浏览器实例
    os.system(r'start chrome --remote-debugging-port=9224 --user-data-dir="D:\评阅用"')
    options = Options()
    options.add_experimental_option('debuggerAddress', '127.0.0.1:9224')

# 在已有的浏览器实例中查找标签页
driver = webdriver.Chrome(options=options)
tabs = driver.window_handles
for tab in tabs:
    driver.switch_to.window(tab)
    if driver.title == '考后核验':
        print('登陆成功')
        break

# 打开Excel表格
wb = openpyxl.load_workbook(r'C:\Users\Administrator\Desktop\考后核验.xlsx')
sheet = wb.active

# 创建照片文件夹
photo_folder = r'C:\Users\Administrator\Desktop\照片'
if not os.path.exists(photo_folder):
    os.mkdir(photo_folder)

# 遍历表格内'K'列和'H'列数据并储存起来
data = []
for row in sheet.iter_rows(min_row=2, values_only=True):
    data.append((row[10], row[7]))

# 遍历数据并储存照片
for item in data:
    photo_url = item[0]
    photo_name = item[1]
    response = requests.get(photo_url)
    with open(os.path.join(photo_folder, photo_name), 'wb') as f:
        f.write(response.content)

print('照片下载完成')
Python自动化下载考后核验照片:Selenium操作浏览器结合Openpyxl读取Excel

原文地址: https://www.cveoy.top/t/topic/fKGD 著作权归作者所有。请勿转载和采集!

免费AI点我,无需注册和登录