http://www.testclass.net/ 測試教程網,專業的selenium 學習網站。javascript
本節重點:css
文件上傳操做也比較常見功能之一,上傳功能沒有用到新有方法或函數,關鍵是思路。html
上傳過程通常要打開一個本地窗口,從窗口選擇本地文件添加。因此,通常會卡在如何操做本地窗口添加上傳文件。java
其實,在selenium webdriver 沒咱們想的那麼複雜;只要定位上傳按鈕,通send_keys添加本地文件路徑就能夠了。絕對路徑和相對路徑均可以,關鍵是上傳的文件存在。下面通地例子演示。jquery
upload_file.htmlweb
<html> <head> <meta http-equiv="content-type" content="text/html;charset=utf-8" /> <title>upload_file</title> <script type="text/javascript" async="" src="http://ajax.googleapis.com/ajax/libs/jquery/1.9.1/jquery.min.js "></script> <link href="http://netdna.bootstrapcdn.com/twitter-bootstrap/2.3.2/css/bootstrap-combined.min.css" rel="stylesheet" /> <script type="text/javascript"> </script> </head> <body> <div class="row-fluid"> <div class="span6 well"> <h3>upload_file</h3> <input type="file" name="file" /> </div> </div> </body> <script src="http://netdna.bootstrapcdn.com/twitter-bootstrap/2.3.2/js/bootstrap.min.js"></script> </html>
upload.pyajax
#coding=utf-8 from selenium import webdriver import os,time driver = webdriver.Firefox() #腳本要與upload_file.html同一目錄 file_path = 'file:///' + os.path.abspath('upload_file.html') driver.get(file_path) #定位上傳按鈕,添加本地文件 driver.find_element_by_name("file").send_keys('D:\\selenium_use_case\upload_file.txt') time.sleep(2) driver.quit()
其它有些應用很差找,因此就本身建立頁面,這樣雖然麻煩,但腳本代碼突出重點。bootstrap
這裏找一139郵箱的實例,有賬號的同窗能夠測試一下~!api
(登錄基礎版的139郵箱,網盤模塊上傳文件。)async
139upload.py
#coding=utf-8 from selenium import webdriver import os,time driver = webdriver.Firefox() driver.get("http://m.mail.10086.cn") driver.implicitly_wait(30) #登錄 driver.find_element_by_id("ur").send_keys("手機號") driver.find_element_by_id("pw").send_keys("密碼") driver.find_element_by_class_name("loading_btn").click() time.sleep(3) #進入139網盤模塊 driver.find_element_by_xpath("/html/body/div[3]/a[9]/span[2]").click() time.sleep(3) #上傳文件 driver.find_element_by_id("id_file").send_keys('D:\\selenium_use_case\upload_file.txt') time.sleep(5) driver.quit()
--------------------------
學習更多selenium 內容: