python - 在 Python 中使用 Selenium Webdriver 下载图像

标签 python selenium selenium-webdriver

我正在尝试使用 Python 中的 Selenium Webdriver 从 URL 下载图像。该站点受登录页面保护,因此不能仅使用请求保存 URL 内容。登录后我可以从站点获取文本,但我不知道如何保存图像。

登录网站后,我可以执行 browser.save_screenshot(filename + '.png') 但该图像与原始图像大小不正确。

我现在的代码是这样的:

browser = webdriver.Chrome('../chromedriver')
browser.get('www.example.com/login')
# send username and password, click submit

browser.get('www.example.com/123')
html = browser.page_source
printData(html)

# this url is an image file
browser.get('www.example.com/get_photo.php?id=123')
browser.save_screenshot(filename + '.png')

理想情况下,我想用类似的东西替换 save_screenshot()

with open(filename + '.jpeg', 'w') as img:
    img.write(browser.download_current_image())

或者甚至是这样的,与弹出菜单交互

browser.right_click()
browser.down_arrow_key()
browser.return_key()

或模拟按键

browser.command_key()
browser.s_key()

This问题给出了我想要的答案,但不适用于 Python。如果有办法在 Python 中执行该问题中建议的任何事情(除了截图),那将是一个很好的解决方案。

最佳答案

这是我使用 Selenium Webdriver 登录然后将 cookie 传递给保存图像的请求,从登录页面后面的 URL 下载图像:

headers = {
"User-Agent":
    "Mozilla/5.0 (Windows NT 6.3; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/44.0.2403.157 Safari/537.36"
}
s = requests.session()
s.headers.update(headers)

for cookie in browser.get_cookies():
    c = {cookie['name']: cookie['value']}
    s.cookies.update(c)

r = s.get(imgurl, allow_redirects=True)
open(filename + '.jpeg', 'wb').write(r.content)

感谢AldoSuwandithis 中向我展示如何执行此操作邮政。我也用过 this帮助我了解如何使用请求下载图像的网站。

关于python - 在 Python 中使用 Selenium Webdriver 下载图像,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/49530566/

相关文章:

selenium - 如何使用 NUnit 和 SpecFlow 按类别驱动的特定顺序运行自动化 bdd UI 测试

java - Selenium 无法获取http

internet-explorer - 如何设置 InternetExplorerDriver 下载目录?

java - 无法单击未聚焦的 EditText 字段

python - 按自定义年度频率重新采样

python - numpy 数组用掩码求平均值

java - 选择特定父级的所有复选框

Python 装饰器 - 类中的 __call__

python - zeroRPC:发送响应后继续运行进程

java - java包错误