Python3+Selenium+Chrome實現(xiàn)自動填寫WPS表單
引言
本文通過python3、第三方python庫Selenium和谷歌瀏覽器Chrome,完成WPS表單的自動填寫。
開發(fā)環(huán)境配置
python3的安裝:略,網上都有教程。
Selenium的安裝:在命令行輸入pip3 install selenium
并回車即可完成安裝,如果不成功,查找網上教程。
Chrome的安裝:略,網上都有教程。
因為Selenium需要ChromeDriver來驅動Chrome,所以還需要下載驅動ChromeDriver。下面重點介紹一下ChromeDriver的安裝(如不太清楚,查找網上教程):
1.確定谷歌瀏覽器的版本號:首先打開谷歌瀏覽器,點擊右上角豎著的三個點—幫助—關于Google Chrome,可以看到谷歌瀏覽器的版本號。
2.下載ChromeDriver:從ChromeDriver鏡像站里找到谷歌瀏覽器版本號對應的文件夾并打開,從中找到對應的系統(tǒng)后下載。
3.配置:將壓縮包解壓后得到可執(zhí)行文件,將其配置到環(huán)境變量Path下,Windows可以直接放到Python的Scripts目錄下(因為該目錄一般都在環(huán)境變量里)。
4.驗證:在命令行輸入chromeDriver并回車,如果不報錯,即完成安裝。 也可以采用火狐瀏覽器(也需要額外下載相應驅動)和PhantomJS瀏覽器引擎(不需要額外下載相應驅動,但是無可視化界面)。
完成以上步驟即可進行代碼編寫。
編寫代碼
這個是測試用的WPS表單。
如上圖,我們先分析一下這個表單:
這個表單已經列舉出大部分WPS表單問題形式:
1.像問題1和3這種需要輸入文字或者數字的都屬于INPUT組件。我們用如下代碼操作這種組件。其中?
要修改為N-1
,表示第N
個問題,比如問題1的話,input_?
應該改為input_0
;問題3的話,input_?
應該改為input_2
。'XXX'
應改改為自己的內容,即文字或者數字。
answer = wait.until(EC.element_to_be_clickable((By.ID, 'select_label_wrap_?_!'))) answer.click()
2.像問題2、4和6(其中問題6后面再說)這種不需要輸入只需要一次選擇的都屬于LABEL組件(本來應該是單選和多選組件,但是WPS表單是用Label組件實現(xiàn)的)。我們用如下代碼操作這種組件。其中?
要修改為N-1
,表示第N
個問題,用法同上;'!'
也要修改為N-1
,表示第N
個選項,比如問題2要選中第1個選項的話,select_label_wrap_?_!
應改為select_label_wrap_1_0
;要選中第2個選項的話,select_label_wrap_?_!
應改為select_label_wrap_1_1
。
answer = wait.until(EC.element_to_be_clickable((By.ID, 'select_label_wrap_?_!'))) answer.click()
對于問題6,雖然其組件也屬于LABEL組件,但涉及到填寫時間,所以利用time
庫來獲取當前時間,與選項作比較后賦值給t
,從而選中第t+1
個選項。其中?
要修改為N-1
,表示第N
個問題,用法同上。
localtime = time.localtime(time.time()) if localtime.tm_hour < 7: t = 0 print("填寫時間為:0700-0900") elif localtime.tm_hour < 11: t = 1 print("填寫時間為:1100-1200") else: t = 2 print("填寫時間為:1800-2000") answer = wait.until(EC.element_to_be_clickable((By.ID, 'select_label_wrap_?_' + str(t)))) answer.click()
3.像問題5這種需要多次點擊選擇的都屬于PICKER組件。這種PICKER組件只能針對性的編寫代碼,好在一般表單只有一個日期PICKER控件。我們用如下代碼操作這種組件。這個不需要修改,但是如果有兩個日期PICKER控件,還要視情況修改,應該沒有這么變態(tài)的表單。
answer = wait.until(EC.element_to_be_clickable((By.CSS_SELECTOR, '.ant-calendar-picker'))) answer.click() answer = wait.until(EC.element_to_be_clickable((By.CSS_SELECTOR, '.ant-calendar-today-btn'))) answer.click()
因此,圖示表單應該用以下代碼進行自動填寫,運行后會彈出Chrome瀏覽器窗口,打開對應WPS表單網頁,自動填入內容,等待10s秒(方便檢查或者反悔,反悔的話關閉網頁即可)后,自動確認完成填寫,最后命令行輸出Perfect!(只有命令行輸出Perfect!或者網頁顯示表單填寫成功才表示自動填寫成功)。
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 import time # WPS表單的網址 url = 'https://f.wps.cn/form-write/uwDUPB2N/' # 完成瀏覽器對象的初始化,設定超時時間為10秒。 browser = webdriver.Chrome() wait = WebDriverWait(browser, 10) browser.get(url) ################################ # 針對INPUT組件,XXX替換成自己的內容。 answer = wait.until(EC.element_to_be_clickable((By.ID, 'input_0'))) answer.send_keys('XXX') # 針對LABEL組件。 answer = wait.until(EC.element_to_be_clickable((By.ID, 'select_label_wrap_1_0'))) answer.click() # 針對INPUT組件,XXX替換成自己的內容。 answer = wait.until(EC.element_to_be_clickable((By.ID, 'input_2'))) answer.send_keys('18') # 針對LABEL組件。 answer = wait.until(EC.element_to_be_clickable((By.ID, 'select_label_wrap_3_0'))) answer.click() # 針對PICKER組件。 answer = wait.until(EC.element_to_be_clickable((By.CSS_SELECTOR, '.ant-calendar-picker'))) answer.click() answer = wait.until(EC.element_to_be_clickable((By.CSS_SELECTOR, '.ant-calendar-today-btn'))) answer.click() # 針對詢問時間的INPUT組件。 localtime = time.localtime(time.time()) if localtime.tm_hour < 7: t = 0 print("填寫時間為:0700-0900") elif localtime.tm_hour < 11: t = 1 print("填寫時間為:1100-1200") else: t = 2 print("填寫時間為:1800-2000") answer = wait.until(EC.element_to_be_clickable((By.ID, 'select_label_wrap_5_' + str(t)))) answer.click() ################################ # 等待10秒 time.sleep(10) # 點擊提交 commit = wait.until(EC.element_to_be_clickable((By.ID, 'submit_button'))) commit.click() # 確認提交 yes = wait.until(EC.element_to_be_clickable((By.ID, 'bind_phone_modal_confirm_button'))) yes.click() # 反饋成功 print('Perfect!')
類似WPS表單,只需要修改網址url和32個#
之間的內容即可。
建議將time.sleep()
中的值調大一些,這樣還可以留出足夠的時間讓自己檢查一下,也可以把以下代碼刪掉,這樣的話,只會自動填寫,不會自動確認。
# 點擊提交 commit = wait.until(EC.element_to_be_clickable((By.ID, 'submit_button'))) commit.click() # 確認提交 yes = wait.until(EC.element_to_be_clickable((By.ID, 'bind_phone_modal_confirm_button'))) yes.click()
這里再給一份針對某表單的代碼,僅供參考學習交流,謹記若表單變動,代碼也要變動:
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 import time url = '填入WPS表單的網址' browser = webdriver.Chrome() wait = WebDriverWait(browser, 10) browser.get(url) answer = wait.until(EC.element_to_be_clickable((By.ID, 'input_0'))) answer.send_keys('XXX') answer = wait.until(EC.element_to_be_clickable((By.ID, 'select_label_wrap_1_1'))) answer.click() answer = wait.until(EC.element_to_be_clickable((By.ID, 'select_label_wrap_2_0'))) answer.click() answer = wait.until(EC.element_to_be_clickable((By.ID, 'select_label_wrap_3_0'))) answer.click() answer = wait.until(EC.element_to_be_clickable((By.CSS_SELECTOR, '.ant-calendar-picker'))) answer.click() answer = wait.until(EC.element_to_be_clickable((By.CSS_SELECTOR, '.ant-calendar-today-btn'))) answer.click() localtime = time.localtime(time.time()) if localtime.tm_hour < 7: t = 0 print("填寫時間為:0700-0900") elif localtime.tm_hour < 11: t = 1 print("填寫時間為:1100-1200") else: t = 2 print("填寫時間為:1800-2000") answer = wait.until(EC.element_to_be_clickable((By.ID, 'select_label_wrap_5_' + str(t)))) answer.click() answer = wait.until(EC.element_to_be_clickable((By.ID, 'input_6'))) answer.send_keys('36.6') answer = wait.until(EC.element_to_be_clickable((By.ID, 'select_label_wrap_7_0'))) answer.click() answer = wait.until(EC.element_to_be_clickable((By.ID, 'select_label_wrap_8_0'))) answer.click() answer = wait.until(EC.element_to_be_clickable((By.ID, 'select_label_wrap_9_0'))) answer.click() answer = wait.until(EC.element_to_be_clickable((By.ID, 'select_label_wrap_10_1'))) answer.click() answer = wait.until(EC.element_to_be_clickable((By.ID, 'select_label_wrap_11_0'))) answer.click() answer = wait.until(EC.element_to_be_clickable((By.ID, 'select_label_wrap_12_0'))) answer.click() time.sleep(5) commit = wait.until(EC.element_to_be_clickable((By.ID, 'submit_button'))) commit.click() yes = wait.until(EC.element_to_be_clickable((By.ID, 'bind_phone_modal_confirm_button'))) yes.click() print('Perfect!')
總結
以上所述是小編給大家介紹的Python3+Selenium+Chrome自動填寫WPS表單,希望對大家有所幫助!
尾言
最后,祝福武漢早日康復,武漢加油!
相關文章
matplotlib源碼解析標題實現(xiàn)(窗口標題,標題,子圖標題不同之間的差異)
這篇文章主要介紹了matplotlib源碼解析標題實現(xiàn)(窗口標題,標題,子圖標題不同之間的差異),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2021-02-02Python matplotlib 畫圖窗口顯示到gui或者控制臺的實例
今天小編就為大家分享一篇Python matplotlib 畫圖窗口顯示到gui或者控制臺的實例,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-05-05動態(tài)設置django的model field的默認值操作步驟
這篇文章主要介紹了動態(tài)設置django的model field的默認值操作步驟,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-03-03jupyter notebook更換皮膚主題的實現(xiàn)
這篇文章主要介紹了jupyter notebook更換皮膚主題的實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2021-01-01python使用pywinauto驅動微信客戶端實現(xiàn)公眾號爬蟲
這個項目是通過pywinauto控制windows(win10)上的微信PC客戶端來實現(xiàn)公眾號文章的抓取。代碼分成server和client兩部分。server接收client抓取的微信公眾號文章,并且保存到數據庫。另外server支持簡單的搜索和導出功能。client通過pywinauto實現(xiàn)微信公眾號文章的抓取。2021-05-05