参考住所: https://www.cnblogs.com/eastmount/p/4810690.html
この記事のセレン+でテストや爬虫類を自動化された共通の場所メソッドのPython、マウス、キーボードの導入、私はあなたを助けるために、この記事の基本的な記事を期待し、エラーや不備がある場合は、合計ながら、〜CSDNを許してくださいこの記事は、シールド、プラス最近(なぜ)記事に自宅にのみ専門家や馬を発表し、真剣に記事やプログラムの猿を読んで、そうあなた自身の庭のブログアカウントを考えるために他人のために夫婦の情熱に影響を与えている、私は非常に良い編集機能を感じていますああ、記事の両側に、後に更新されます。最初の記事を記録し、この最後のストップは、私はここでより多くの記事を共有することを願っています!
以前のディレクトリ:
[Pythonの爬虫類] WindowsのPhantomJSとCasperJSと入門プレゼンテーション(上)下にインストール
[Pythonの爬虫類]のWindowsでのインストールPIP + Phantomjs +セレン
[Pythonの爬虫類]のFirefoxとChromeへのセレン自動的にアクセスし、検索のスクリーンショットを実装
[Pythonの爬虫類】セレン自動的163個のメールボックスを記録し、位置決め要素が導入された
情報へのPython爬虫類]セレン+ Phantomjsダイナミックアクセス〔とCSDNリソースのコメント
測位方法素子
公式ウェブサイトのアドレスは:http://selenium-python.readthedocs.org/locating-elements.html
(要素を見つけます)、あなたが最も適したソリューションを選択することができ、Webページの要素を見つけるための様々な戦略があり、セレンは、以下の方法を提供し、ページの要素を定義するには:
1
2
3
4
5
6
7
8
|
find_element_by_id
find_element_by_name
find_element_by_xpath
find_element_by_link_text
find_element_by_partial_link_text
find_element_by_tag_name
find_element_by_class_name
find_element_by_css_selector
|
ここでは、(これらのメソッドは、リストを返します)複数の要素を見つけることです。
1
2
3
4
5
6
7
|
find_elements_by_name
find_elements_by_xpath
find_elements_by_link_text
find_elements_by_partial_link_text
find_elements_by_tag_name
find_elements_by_class_name
find_elements_by_css_selector
|
上記の指定された公開方法に加えて、2つの有用なページ・オブジェクト・ロケータープライベートメソッドもあります。これらの2つの方法は、プライベートとfind_elements find_elementです。
方法は、XPath配置相対パスだけでなく、良好なCSS方式で使用されます。例えば:
<HTML> <BODY> <フォームのid = "loginForm"> <入力名= "ユーザ名"タイプ= "テキスト" /> <入力名= "パスワード"タイプ= "パスワード" /> <入力名= "継続"タイプ= "送信"値は= "ログイン" /> <入力名= "継続"タイプ= "ボタン"値= "クリア" /> </ FORM> </ BODY> <HTML>
次のようにメソッド名の位置決め要素は次のとおりです。
ユーザ名= driver.find_element_by_xpath( "//フォーム[入力/ @名= 'ユーザ名']") 、ユーザ名= driver.find_element_by_xpath( "//フォーム/入力[1] [ID = 'loginForm' @]") 、ユーザ名=ドライバ.find_element_by_xpath( "//入力[名@ = 'ユーザ名']")
[1]フォーム入力のサブ要素、name属性とユーザ名を達成値によって最初の要素は
、[2]第一のサブエレメント入力されたID = loginFormフォーム要素値によって見出さ
[3]及びプロパティ名がユーザ名と呼ばれています第一の入力要素
II。操作エレメントの方法
(要素を見つけます)私たちは通常、すべての操作がWebElementインタフェースに従うことによって、ページと相互作用し、対象物を操作する必要があるオブジェクトの位置を特定程度が完了した後、一般的なオペレーティング要素法:
1
2
3
4
|
clear 清除元素的内容
send_keys 模拟按键输入
click 点击元素
submit 提交表单
|
例えば、Firefoxブラウザへの自動アクセスは自動的に163個のメールボックスをログに記録しました。
セレン輸入webdriverをから selenium.webdriver.common.keysから鍵をインポートする インポート時 #ログイン163のメール ドライバ= webdriver.Firefox() driver.get( "http://mail.163.com/") elem_user = driver.find_element_by_name( "ユーザ名") elem_user.clear elem_user.send_keys( "15201615157") elem_pwd = driver.find_element_by_name( "パスワード") elem_pwd.clear elem_pwd.send_keys( "******") elem_pwd.send_keys(Keys.RETURN) #driver.find_element_by_id( "loginBtn")。クリックしてください() #のdriver.find_element_by_id( "loginBtn")。()提出 time.sleepは(5) driver.titleの中で"百度"を主張する ドライバー。 )(クローズ )(driver.quit
まず名前で、すべてのユーザー名とパスワードを検索し、その後、(明確なメソッドを呼び出して)正しいユーザー名とパスワードを入力するように(「**」)send_keysで、その他のヒント「あなたのパスワードを入力してください」などの入力ボックスのデフォルトのコンテンツを、クリアし、最後にクリックし()をクリックしてログインを入力するには同等のログインボタンやsend_keys(Keys.RETURN)、提出()フォームを送信します。
PS:あなたはsend_keys(U「中国のユーザー名」)を使用してコーディングエラーを防ぐために中国語を入力する必要がある場合。
値を得るための3つの.WebElementインターフェース
一般的な値はWebElementインタフェースによって得ることができ、これらの値も非常に重要です。
1
2
3
4
5
6
7
8
9
10
11
|
size 获取元素的尺寸
text 获取元素的文本
get_attribute(name) 获取属性值
location 获取元素坐标,先找到要获取的元素,再调用该方法
page_source 返回页面源码
driver.title 返回页面标题
current_url 获取当前页面的URL
is_displayed() 设置该元素是否可见
is_enabled() 判断元素是否被使用
is_selected() 判断元素是否被选中
tag_name 返回元素的tagName
|
サンプルコード:
from selenium import webdriver from selenium.webdriver.common.keys import Keys import time driver = webdriver.PhantomJS(executable_path="G:\phantomjs-1.9.1-windows\phantomjs.exe") driver.get("http://www.baidu.com/") size = driver.find_element_by_name("wd").size print size #尺寸: {'width': 500, 'height': 22} news = driver.find_element_by_xpath("//div[@id='u1']/a[1]").text print news #文本: 新闻 href = driver.find_element_by_xpath("//div[@id='u1']/a[2]").get_attribute('href') name = driver.find_element_by_xpath("//div[@id='u1']/a[2]").get_attribute('name') print href,name #属性值: http://www.hao123.com/ tj_trhao123 location = driver.find_element_by_xpath("//div[@id='u1']/a[3]").location print location #坐标: {'y': 19, 'x': 498} print driver.current_url #当前链接: https://www.baidu.com/ print driver.title #标题: 百度一下, 你就知道 result = location = driver.find_element_by_id("su").is_displayed() print result #是否可见: True
其中图片解释如下图所示。
四.鼠标操作
在现实的自动化测试中关于鼠标的操作不仅仅是click()单击操作,还有很多包含在ActionChains类中的操作。如下:
1
2
3
4
5
6
|
context_click(elem) 右击鼠标点击元素elem,另存为等行为
double_click(elem) 双击鼠标点击元素elem,地图web可实现放大功能
drag_and_drop(source,target) 拖动鼠标,源元素按下左键移动至目标元素释放
move_to_element(elem) 鼠标移动到一个元素上
click_and_hold(elem) 按下鼠标左键在一个元素上
perform() 在通过调用该函数执行ActionChains中存储行为
|
举例如下图所示,获取通过鼠标右键另存为百度图片logo。代码:
import time from selenium import webdriver from selenium.webdriver.common.keys import Keys from selenium.webdriver.common.action_chains import ActionChains driver = webdriver.Firefox() driver.get("http://www.baidu.com") #鼠标移动至图片上 右键保存图片 elem_pic = driver.find_element_by_xpath("//div[@id='lg']/img") print elem_pic.get_attribute("src") action = ActionChains(driver).move_to_element(elem_pic) action.context_click(elem_pic) #重点:当右键鼠标点击键盘光标向下则移动至右键菜单第一个选项 action.send_keys(Keys.ARROW_DOWN) time.sleep(3) action.send_keys('v') #另存为 action.perform() #获取另存为对话框(失败) alert.switch_to_alert() alert.accept()
效果如下图所示,通过xpath定位到图片位置并右击鼠标,在弹出的菜单中选择“另存为图片”。但是如何点击“另存为对话框”的“保存”按钮是个难点,目前刚学习阶段,境界没到无法解决。原因:
WebDriver cannot directly interact with dialog windows this is because dialog windows are the domain of the operating system and not the webpage
selenium 右键下载图片,结合sikuli - tobecrazy
Selenium WebDriver 中鼠标和键盘事件分析及扩展
Selenium Windows Save/Open Open Dialouge - StackOver
书籍《selenium2 python自动化测试》 作者:虫师
五.键盘操作
参考:http://selenium-python.readthedocs.org/api.html
前面讲述了鼠标操作,现在讲述键盘操作。在webdriver的Keys类中提供了键盘所有的按键操作,当然也包括一些常见的组合键操作如Ctrl+A(全选)、Ctrl+C(复制)、Ctrl+V(粘贴)。更多键参考官方文档对应的编码。
1
2
3
4
5
6
7
8
9
10
11
12
|
send_keys(Keys.ENTER) 按下回车键
send_keys(Keys.TAB) 按下Tab制表键
send_keys(Keys.SPACE) 按下空格键space
send_keys(Kyes.ESCAPE) 按下回退键Esc
send_keys(Keys.BACK_SPACE) 按下删除键BackSpace
send_keys(Keys.SHIFT) 按下shift键
send_keys(Keys.CONTROL) 按下Ctrl键
send_keys(Keys.ARROW_DOWN) 按下鼠标光标向下按键
send_keys(Keys.CONTROL, 'a' ) 组合键全选Ctrl + A
send_keys(Keys.CONTROL, 'c' ) 组合键复制Ctrl + C
send_keys(Keys.CONTROL, 'x' ) 组合键剪切Ctrl + X
send_keys(Keys.CONTROL, 'v' ) 组合键粘贴Ctrl + V
|
这里使用的例子参考虫师的书籍《selenium2 python自动化测试》,推荐该书给大家。代码还是非常有意思的,大家自己去感受下吧~
#coding=utf-8 import time from selenium import webdriver from selenium.webdriver.common.keys import Keys driver = webdriver.Firefox() driver.get("http://www.baidu.com") #输入框输入内容 elem = driver.find_element_by_id("kw") elem.send_keys("Eastmount CSDN") time.sleep(3) #删除一个字符CSDN 回退键 elem.send_keys(Keys.BACK_SPACE) elem.send_keys(Keys.BACK_SPACE) elem.send_keys(Keys.BACK_SPACE) elem.send_keys(Keys.BACK_SPACE) time.sleep(3) #输入空格+"博客" elem.send_keys(Keys.SPACE) elem.send_keys(u"博客") time.sleep(3) #ctrl+a 全选输入框内容 elem.send_keys(Keys.CONTROL,'a') time.sleep(3) カット#1 CTRL + Xコンテンツ入力ボックス elem.send_keys(Keys.CONTROL、 'X') time.sleep(3) #再入力する検索入力ボックス elem.send_keys(Keys.CONTROL、 'V') time.sleep(3 ) #Enterキーをクリックすることで置き換える driver.find_element_by_id( "SU")。send_keys(Keys.ENTER) time.sleepは(3) driver.quit()