当前位置: 代码网 > it编程>前端脚本>Python > Python使用Selenium批量自动化获取并下载图片的方法

Python使用Selenium批量自动化获取并下载图片的方法

2024年11月22日 Python 我要评论
selenium批量自动化获取并下载图片在现代的web开发中,自动化测试和数据抓取已经成为不可或缺的一部分。selenium作为一款强大的自动化测试工具,不仅可以用于测试web应用,还可以用于批量获取

selenium批量自动化获取并下载图片

在现代的web开发中,自动化测试和数据抓取已经成为不可或缺的一部分。selenium作为一款强大的自动化测试工具,不仅可以用于测试web应用,还可以用于批量获取网页上的图片。本文将介绍如何使用selenium批量自动化获取并下载图片。

一、准备工作

安装selenium:首先,你需要在你的系统中安装selenium。你可以使用pip来安装:

pip install selenium

下载webdriver:selenium需要与webdriver配合使用,webdriver是一个浏览器驱动,用于执行浏览器操作。你需要根据你的浏览器类型下载对应的webdriver。例如,如果你使用的是chrome,你需要下载chromedriver。

导入必要的库:在python脚本中,你需要导入selenium的库以及用于处理图片的库(如pil)。

from selenium import webdriver  
from pil import image  
import io

二、编写代码

启动浏览器驱动:创建一个浏览器驱动实例,并打开一个网页。这里以chrome为例:

driver = webdriver.chrome('path/to/chromedriver')  
driver.get('http://example.com')

查找图片元素:使用selenium的定位 器(locators)来查找页面上的图片元素。你可以使用css选择器、xpath等来定位图片元素。例如,使用css选择器定位所有的img标签:

images = driver.find_elements_by_css_selector('img')

下载图片:对于每个找到的图片元素,提取其src属性,然后使用pil库下载图片。这里是一个简单的示例:

for image in images:  
    image_url = image.get_attribute('src')  
    response = driver.execute_script("return fetch('" + image_url + "');")  
    image_data = response.content  
    image = image.open(io.bytesio(image_data))  
    image.save(image_url.split('/')[-1])  # 将图片保存到本地,文件名保持不变

关闭浏览器驱动:完成图片下载后,关闭浏览器驱动。

driver.quit()

三、注意事项

跨域问题:如果图片来自于不同的域,你可能会遇到跨域问题。在这种情况下,你需要处理浏览器的同源策略限制。一种解决方法是使用浏览器插件或服务来允许跨域请求。
图片大小和分辨率:在下载图片时,你可能需要调整图片的大小和分辨率以满足你的需求。你可以在保存图片时使用pil库的resize方法来调整图片大小。例如:image.resize((width, height))。

完整例子:

from selenium import webdriver
from selenium.webdriver.common.by import by
import time
import requests
from io import bytesio
from pil import image

def spider(url):
    driver = webdriver.chrome()
    driver.get(url)
    driver.maximize_window()  # 窗口最大化
    time.sleep(30)
    a=1
    for j in range(2,25):
        try:
            try:
                for i in range(1,100):
                    a+=1
                    image_url=driver.find_element(by.xpath,'//*[@id="sobey_editor_content"]/p/img[{}]'.format(i)).get_attribute("src")
                    print(image_url)
                    #//*[@id="root"]/div/div/div/div[1]/div/div[2]/div/div[3]/div/div/div/div[4]
                    #//*[@id="root"]/div/div/div/div[1]/div/div[2]/div/div[3]/div/div/div/div[23]
                    response = requests.get(image_url)
                    image_data = bytesio(response.content)
                    image = image.open(image_data)
                    image.save("image/{}.jpg".format(a))
                    print("{}下载成功".format(a))
            except:
                print("已下载完")
            driver.find_element(by.xpath,'//*[@id="root"]/div/div/div/div[1]/div/div[2]/div/div[3]/div/div/div/div[{}]'.format(j+1)).click()
            time.sleep(0.5)
        except:
            print("未能下载。")
            pass
    driver.quit()
    quit()

if __name__ == '__main__':
    spider('https://yunquer.cn/web/#/previewtextbook?contentid_=e8e86045f7a441e5828da5c3b21bcacc&uip=1')

到此这篇关于python使用selenium批量自动化获取并下载图片的方法的文章就介绍到这了,更多相关python selenium获取并下载图片内容请搜索代码网以前的文章或继续浏览下面的相关文章希望大家以后多多支持代码网!

(0)

相关文章:

版权声明:本文内容由互联网用户贡献,该文观点仅代表作者本人。本站仅提供信息存储服务,不拥有所有权,不承担相关法律责任。 如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 2386932994@qq.com 举报,一经查实将立刻删除。

发表评论

验证码:
Copyright © 2017-2025  代码网 保留所有权利. 粤ICP备2024248653号
站长QQ:2386932994 | 联系邮箱:2386932994@qq.com