Я создал скрипт, который отправляется на сайт аукциона недвижимости, который следит за ценой и предупреждает меня о любых изменениях. Первоначально я сделал это, чтобы контролировать 1 URL за один раз. Теперь мне нужно, чтобы он отслеживал более 1 URL и одновременно выполнял один и тот же процесс.
Я пробовал зацикливать URL-адреса в browser.get
, но мне это не помогло (IDK, если я написал неправильно, вероятно, сделал). Но мне это нужно, чтобы открыть множество новых вкладок и перейти к URL-адресам, или как-то еще, чтобы он мог контролировать все.
Вот весь мой код
import time
import requests
from selenium import webdriver
from selenium.webdriver.common.by import By
from selenium.webdriver.support.ui import WebDriverWait
from selenium.webdriver.support import expected_conditions as EC
from selenium.webdriver.support.ui import Select
from selenium.webdriver.common.keys import Keys
from selenium.common.exceptions import NoSuchElementException
import ssl
from twilio.rest import Client
from twilio.rest import TwilioRestClient
from bs4 import BeautifulSoup as soup
urls = ['https://www.hubzu.com/property/90089436968-730-Trillium-Ln-Lilburn-GA-30047',
'https://www.hubzu.com/property/90016097522-225-Marriott-Ave-Schenectady-NY-12304',
'https://www.hubzu.com/property/90016098285-17-Spring-Meadows-Dr-Ormond-Beach-FL-32174'
]
browser = webdriver.Chrome()
# Start URL switch tryouts.
while True:
for url in urls:
browser.get((url))
#This is the process i need all urls to do.
time.sleep(2)
address = soup(browser.page_source, 'html.parser').find('span', {'class':'h1'}).text
propertyprice = browser.find_element_by_css_selector('span.current-bid')
currentBidText = propertyprice.text
try:
WebDriverWait(browser, 90000).until_not(
EC.text_to_be_present_in_element((By.CSS_SELECTOR, 'span.current-bid'), currentBidText)
)
finally:
print("+++ Send notifications.")
account_sid = "***"
auth_token = "***"
client = Client(account_sid, auth_token)
PhoneNumber1 = "+***"
PhoneNumber2 = "+***"
print("+ Send notifications to: ", PhoneNumber1, " and ", PhoneNumber2)
sendTo1 = "{\"binding_type\":\"sms\",\"address\":\"" + PhoneNumber1 + "\"}"
print("+ sendTo1: ", sendTo1)
sendTo2 = "{\"binding_type\":\"sms\",\"address\":\"" + PhoneNumber2 + "\"}"
print("+ sendTo2: ", sendTo2)
notify_service_sid = "***"
notification = client.notify.services(notify_service_sid).notifications.create(
body='There has been a change at: '+address,
to_binding=[sendTo1, sendTo2]
)
print("+ Notification SID: ", notification.sid)
print("+++ Exit.")
continue
PS: имейте в виду, что если аукционы истекли, возникнет ошибка. Потому что не может найти span.current-bid