循环打印屏幕
Loop for print screen
需要一些帮助。我得到了这个 python 代码来加载 url 并进行屏幕打印。
我需要实现这个:
- 而不是数组,从文本文件
中读取url
- 对加载的每个 url 进行屏幕打印并保存。使用代码,屏幕打印被覆盖
from selenium import webdriver
from time import sleep
driver = webdriver.Firefox()
url = ["http://google.com", "http://cisco.com"]
for element in url:
driver.get(element)
driver.get_screenshot_as_file("screenshot.png")
sleep(2)
driver.quit()
print("end...")
将URL存储在文本文件中,然后逐行读取。然后使用文件名和 URL.
的主机名截屏
我已经修改了您的代码,可以将每个 url 的屏幕截图存储在单独的文件中。我用过 Python 3.6.9.
目录结构:
.
├── links.txt
├── requirements.txt
└── screenshots_of_links.py
links.txt
:
http://google.com
http://cisco.com
requirements.txt
:
selenium==3.141.0
urllib3==1.25.10
screenshots_of_links.py
:
from selenium import webdriver
from urllib.parse import urlparse
from time import sleep
driver = webdriver.Firefox()
with open("links.txt") as url_file:
for line in url_file.readlines():
url = line.strip()
if url != "":
driver.get(url)
host = urlparse(url).hostname
driver.get_screenshot_as_file("{}.png".format(host))
sleep(2)
driver.quit()
print("end...")
输出:
修改详情:
- 从
links.txt
文本文件中读取 URLs。
- Trim 文件的每一行。
- 解析每个 URL 并使用主机名作为屏幕截图的文件名。
urlparse(url).hostname
returns 有效的主机名 URL。
参考:
需要一些帮助。我得到了这个 python 代码来加载 url 并进行屏幕打印。
我需要实现这个:
- 而不是数组,从文本文件 中读取url
- 对加载的每个 url 进行屏幕打印并保存。使用代码,屏幕打印被覆盖
from selenium import webdriver
from time import sleep
driver = webdriver.Firefox()
url = ["http://google.com", "http://cisco.com"]
for element in url:
driver.get(element)
driver.get_screenshot_as_file("screenshot.png")
sleep(2)
driver.quit()
print("end...")
将URL存储在文本文件中,然后逐行读取。然后使用文件名和 URL.
的主机名截屏我已经修改了您的代码,可以将每个 url 的屏幕截图存储在单独的文件中。我用过 Python 3.6.9.
目录结构:
.
├── links.txt
├── requirements.txt
└── screenshots_of_links.py
links.txt
:
http://google.com
http://cisco.com
requirements.txt
:
selenium==3.141.0
urllib3==1.25.10
screenshots_of_links.py
:
from selenium import webdriver
from urllib.parse import urlparse
from time import sleep
driver = webdriver.Firefox()
with open("links.txt") as url_file:
for line in url_file.readlines():
url = line.strip()
if url != "":
driver.get(url)
host = urlparse(url).hostname
driver.get_screenshot_as_file("{}.png".format(host))
sleep(2)
driver.quit()
print("end...")
输出:
修改详情:
- 从
links.txt
文本文件中读取 URLs。 - Trim 文件的每一行。
- 解析每个 URL 并使用主机名作为屏幕截图的文件名。
urlparse(url).hostname
returns 有效的主机名 URL。
参考: