from selenium import webdriver from time import sleep driver = webdriver.Chrome() driver.implicitly_wait(10) #隱形等待 driver.get('https://www.baidu.com/') sleep(1) #以五種定位方式定位到百度首頁的搜索輸入框 kw_find = driver.find_element_by_id('kw') #kw_find= driver.find_element_by_class_name('s_ipt') #kw_find= driver.find_element_by_name('wd') #kw_find = driver.find_element_by_xpath('//*[@id="kw"]') #kw_find = driver.find_element_by_css_selector('#kw') #id用#kw,class用.s_ipt ,與css的簡寫方式相同 #send_keys() 是selenium自帶的方法,用來輸入文本 kw_find.send_keys('selenium') #使用id定位方式定位到搜索按鈕 su_find = driver.find_element_by_id('su') #click() 是selenium自帶的方法,用來點擊定位的元素 su_find.click() sleep(1) driver.quit()
一樣用百度首頁的的其中一個hao123來練習 link_text和partial_link_text定位方式css
from selenium import webdriver from time import sleep driver = webdriver.Chrome() driver.implicitly_wait(10) #隱形等待 driver.get('https://www.baidu.com/') sleep(1) #定位hao123頁面的超連接並點擊 hao123_find = driver.find_element_by_link_text('hao123') #這個方法比較直接,即經過超文本連接上的文字信息來定位元素 hao123_find = driver.find_element_by_partial_link_text('hao1') #這個方法是上一個方法的擴展。當你不能準確知道超連接上的文本信息或者只想經過一些關鍵字進行匹配時,能夠使用這個方法來經過部分連接文字進行匹配 hao123_find.click() sleep(1) driver.quit()
from selenium import webdriver from time import sleep driver = webdriver.Chrome() driver.get('https://www.baidu.com') for img in driver.find_elements_by_tag_name("img"): print(img.text) print(img.size) print(img.tag_name) sleep(2) driver.quit()
運行發現沒有圖片名稱打印出來,說明百度首頁,全部圖片都沒有給出text這個屬性。web