Python爬蟲基礎(chǔ)之selenium庫(kù)的用法總結(jié)
一、selenium簡(jiǎn)介

總的來(lái)說(shuō): selenium庫(kù)主要用來(lái)做瀏覽器的自動(dòng)化腳本庫(kù)。
二、selenium基本用法
from selenium import webdriver
url = 'http://www.baidu.com'
# 將webdriver實(shí)例化
path = 'C:\Program Files (x86)\Python38-32\chromedriver.exe'
browser = webdriver.Chrome(executable_path = path)
# 用谷歌瀏覽器訪問(wèn)百度
r = browser.get(url)
with open ('test.txt','wb+') as f:
f.write(r.content)
三、常用用法
'''
代碼功能:selenium是的常用用法
時(shí)間:@Date: 2021-05-22 21:37:05
'''
from selenium import webdriver
# 導(dǎo)入Options類
from selenium.webdriver.chrome.options import Options
url = "https://movie.douban.com/"
# Options的實(shí)例化
chrome_options = Options()
# 設(shè)置瀏覽器參數(shù)
# --headless 是不顯示瀏覽器啟動(dòng)以及執(zhí)行過(guò)程
chrome_options.add_argument('--headless')
# 設(shè)置lang和User-Agent信息,防止反爬檢測(cè)
chrome_options.add_argument('lang=zh_CN.utf-8')
UserAgent = 'Mozilla/5.0 (Windows NT 10.0; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/90.0.4430.93 Safari/537.36'
chrome_options.add_argument('User-Agent='+UserAgent)
# 啟動(dòng)瀏覽器并設(shè)置chrome_options參數(shù)
driver = webdriver.Chrome(chrome_options=chrome_options)
# 設(shè)置瀏覽器窗口最大化
# driver.maximize_window()
# # 設(shè)置瀏覽器窗口最小化
# driver.minimize_window()
driver.get(url)
# 獲取網(wǎng)頁(yè)的標(biāo)題
print(driver.title)
# page_source是獲取網(wǎng)頁(yè)的HTML代碼
print(driver.page_source)
四、cookie的設(shè)置、獲取與刪除
from selenium import webdriver
import time
# 啟動(dòng)瀏覽器
driver = webdriver.Chrome()
driver.get('https://www.youdao.com')
time.sleep(5)
# 添加cookie
driver.add_cookie({'name':'login','value':'登錄'})
# 獲取全部cookie
allCookies = driver.get_cookies()
print('全部cookies',allCookies)
# 獲取name為login的cookie
cookie = driver.get_cookie('login')
print('name為login的cookie',cookie)
# 刪除單個(gè)cookie
driver.delete_cookie('login')
print("\n--------------剩余的cookies\n",driver.get_cookies())
# 刪除全部cookies
driver.delete_all_cookies()
print("-------------剩余的cookies------------\n",driver.get_cookies())
time.sleep(60)
五、文件的上傳與下載 文件上傳upload
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Document</title>
</head>
<body>
<h1>配合selenium模擬上傳文件</h1>
<input type='file' name='file' />
</body>
</html>
'''
代碼功能:selenium上傳文件 --配合upload.html使用
時(shí)間:@Date: 2021-05-23 09:56:53
'''
from selenium import webdriver
import time
driver = webdriver.Chrome()
url = 'http://localhost:52330/selenium/upload.html'
driver.get(url)
ele = driver.find_element_by_name('file')
print("獲取到的元素",ele)
# 注意路徑不能有中文字符
ele.send_keys('D:\dcsdk_eventv3.db')
time.sleep(10)
下載文件
'''
代碼功能:模擬文件下載
時(shí)間:@Date: 2021-05-23 10:21:28
'''
from selenium import webdriver
import time
# 設(shè)置文件保存路徑,如果不設(shè)置,會(huì)默認(rèn)保存到Downloads文件夾
options = webdriver.ChromeOptions()
prefs = {'download.default_directory':'D:\\'}
options.add_experimental_option('prefs',prefs)
# 啟動(dòng)瀏覽器
driver = webdriver.Chrome()
# 下載PC版微信
driver.get('https://pc.weixin.qq.com')
# 瀏覽器窗口最大化
driver.maximize_window()
time.sleep(5)
# 點(diǎn)擊下載按鈕
driver.find_element_by_class_name('download-button').click()
time.sleep(30)
六、窗口的切換
from selenium import webdriver
import time
url = 'https://www.baidu.com/'
driver = webdriver.Chrome()
# 隱式等待,一次設(shè)置對(duì)整個(gè)driver的周期都起作用
driver.implicitly_wait(30)
driver.get(url)
# 使用js開啟新的窗口
js = 'window.open("https://www.sogou.com/")'
driver.execute_script(js)
# 獲取當(dāng)前顯示的窗口信息
current_window = driver.current_window_handle
print(driver)
# 獲取瀏覽器的全部窗口信息
handles = driver.window_handles
print('獲取到的窗口全部信息\n------------------\n',handles)
'''
獲取到的窗口全部信息
------------------
['CDwindow-7FB808B4F24EF5385A9AFBDC21FA13B9', 'CDwindow-E879C0A64E734C3F88468A4388F48E3B']
'''
# 設(shè)置延時(shí)看切換的效果
time.sleep(3)
# 根據(jù)窗口信息進(jìn)行窗口切換
# 切換到百度搜索的窗口
driver.switch_to_window(handles[0])
time.sleep(3)
# 切換到搜狗窗口
driver.switch_to_window(handles[1])
七、項(xiàng)目實(shí)戰(zhàn)
'''
代碼功能:熟悉selenium的自動(dòng)化操作
時(shí)間:2020/5/22
'''
from selenium import webdriver
from selenium.webdriver.common.keys import Keys
import time
# Keys 類中定義了很多快捷鍵
url = 'https://wwww.baidu.com'
path = 'C:\Program Files (x86)\Python38-32\chromedriver.exe'
driver = webdriver.Chrome(executable_path=path)
driver.get(url)
# 獲取輸入框標(biāo)簽對(duì)象
element = driver.find_element_by_id('kw')
# 輸入框輸入內(nèi)容
element.send_keys('python你')
time.sleep(2)
# 刪除最后一個(gè)文字
element.send_keys(Keys.BACK_SPACE)
time.sleep(2)
# 添加空格加教程
element.send_keys(Keys.SPACE)
element.send_keys("教程")
time.sleep(2)
# ctrl+a 全選輸入框內(nèi)容
element.send_keys(Keys.CONTROL, 'a')
time.sleep(2)
# ctrl+x 剪切輸入框內(nèi)容
element.send_keys(Keys.CONTROL, 'x')
time.sleep(2)
# ctrl+v 復(fù)制
element.send_keys(Keys.CONTROL, 'v')
time.sleep(2)
# 回車鍵
driver.find_element_by_id('su').send_keys(Keys.ENTER)
time.sleep(10)
到此這篇關(guān)于Python爬蟲基礎(chǔ)之selenium庫(kù)的用法總結(jié)的文章就介紹到這了,更多相關(guān)Python selenium庫(kù)內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Pandas如何對(duì)帶有Multi-column(多列名稱)的數(shù)據(jù)排序并寫入Excel中
這篇文章主要介紹了Pandas如何對(duì)帶有Multi-column(多列名稱)的數(shù)據(jù)排序并寫入Excel中問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-02-02
python?字符串模糊匹配Fuzzywuzzy的實(shí)現(xiàn)
本文主要介紹了python?字符串模糊匹配Fuzzywuzzy的實(shí)現(xiàn),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2022-07-07
Python編程中的文件讀寫及相關(guān)的文件對(duì)象方法講解
這篇文章主要介紹了Python編程中的文件讀寫及相關(guān)的文件對(duì)象方法講解,其中文件對(duì)象方法部分講到了對(duì)文件內(nèi)容的輸入輸出操作,需要的朋友可以參考下2016-01-01
PyQT5 實(shí)現(xiàn)快捷鍵復(fù)制表格數(shù)據(jù)的方法示例
這篇文章主要介紹了PyQT5 實(shí)現(xiàn)快捷鍵復(fù)制表格數(shù)據(jù)的方法示例,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-06-06
Python函數(shù)調(diào)用的幾種方式(類里面,類之間,類外面)
本文主要介紹了Python函數(shù)調(diào)用的幾種方式(類里面,類之間,類外面),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2023-07-07
Python利用Flask動(dòng)態(tài)生成漢字頭像
這篇文章主要為大家詳細(xì)介紹了Python如何利用Flask動(dòng)態(tài)生成一個(gè)漢字頭像,文中的示例代碼講解詳細(xì),對(duì)我們學(xué)習(xí)Python有一定的幫助,需要的可以參考一下2023-01-01
python使用wmi模塊獲取windows下硬盤信息的方法
這篇文章主要介紹了python使用wmi模塊獲取windows下硬盤信息的方法,涉及Python獲取系統(tǒng)硬件信息的相關(guān)技巧,需要的朋友可以參考下2015-05-05
python微元法計(jì)算函數(shù)曲線長(zhǎng)度的方法
今天小編就為大家分享一篇python微元法計(jì)算函數(shù)曲線長(zhǎng)度的方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2018-11-11

