怎么用ChromeDriver ?

从这里下载最新的driver版本并解压
 
# 好吧,这个命令是给linux or osx用户准备的
# windows用户直接手点吧 by 乙醇
unzip chromedriver_linux32_x.x.x.x.zip
 
 
你会得到一个 chromedriver 的可执行文件. 现在用下面的代码就可以了:
 
driver = webdriver.Chrome(executable_path="/path/to/chromedriver")
# windows如果还不行就把chrome driver扔到python的安装目录下 by乙醇
 
 
Selenium 2支持XPath 2.0吗?
参考: http://seleniumhq.org/docs/03_webdriver.html#how-xpath-works-in-webdriver
 
Selenium把xpath处理委托给了浏览器的xpath解析引擎。所以浏览器支持什么,selenium就支持什么。如果那些奇葩的浏览器没有xpath引擎的话(IE6,7,8),那么在这些大爷上selenium就只支持xpath1.0了。
 
怎样才能滚到页面的底部?
参考: http://blog.varunin.com/2011/08/scrolling-on-pages-using-selenium.html
 
你可以用 execute_script方法来处理这个。 调用原生javascript的API,这样你想滚到哪里就能滚到哪里。
 
下面的代码演示了如何滚到页面的最下面:
 
driver.execute_script("window.scrollTo(0, document.body.scrollHeight);")
window <http://www.w3schools.com/jsref/obj_window.asp>对象
的 scrollTo <http://www.w3schools.com/jsref/met_win_scrollto.asp> . 方法可以滚到页面上的任何位置。 scrollHeight <http://www.w3schools.com/jsref/dom_obj_all.asp>是dom元素的通用属性。document.body.scrollHeight 会返回body元素的高度,基本上就是页面的高度了。
 
 
 
如何使用Firefox的profile来自动保存下载的文件
参考: http://stackoverflow.com/questions/1176348/access-to-file-download-dialog-in-firefox
参考: http://blog.codecentric.de/en/2010/07/file-downloads-with-selenium-mission-impossible/
 
首先,你要保存的的文件类型你造么?
要搞清楚要自动下载的文件类型,用 curl就好了
 
curl -I URL | grep "Content-Type"
 
 
另一种方式是使用 requests <http://python-requests.org>_ module, 这样搞:
 
import requests
print requests.head('http://www.python.org').headers['content-type']
 
 
 
 
当你确定了content type之后,调用browser.helperApps.neverAsk.saveToDisk来设置firefox的profile就好了。
 
这是例子:
 
复制代码
import os
 
from selenium import webdriver
 
fp = webdriver.FirefoxProfile()
 
fp.set_preference("browser.download.folderList",2)
fp.set_preference("browser.download.manager.showWhenStarting",False)
fp.set_preference("browser.download.dir", os.getcwd())
fp.set_preference("browser.helperApps.neverAsk.saveToDisk", "application/octet-stream")
 
browser = webdriver.Firefox(firefox_profile=fp)
browser.get("http://pypi.python.org/pypi/selenium")
browser.find_element_by_partial_link_text("selenium-2").click()
复制代码
 
 
 
 
上例中, application/octet-stream 就是content type。
 
browser.download.dir 指定了文件自动保存的文件夹。
 
如何在打开Firefox的同时打开firebug ?
首先下载Firebug XPI文件(这个就是friefox的扩展程序文件--by乙醇),然后再调用firefox profile的add_extension方法。
 
复制代码
from selenium import webdriver
 
fp = webdriver.FirefoxProfile()
 
fp.add_extension(extension='firebug-1.8.4.xpi')
fp.set_preference("extensions.firebug.currentVersion", "1.8.4") #Avoid startup screen
browser = webdriver.Firefox(firefox_profile=fp)

最新文章

  1. CentOS安装JDK-1.7
  2. .net网站的文件上传读取进度条和断点下载
  3. 12 抽象函数-abstract
  4. input标签实现让光标不出现!
  5. Mina、Netty、Twisted一起学(三):TCP消息固定大小的前缀(Header)
  6. LeetCode2:Median of Two Sorted Arrays
  7. HDU 2091 空心三角形(模拟)
  8. python文件打包格式,pip包管理
  9. XGrid绑定(转)
  10. 58. Length of Last Word
  11. Swift 中的静态方法继承
  12. google在线測试练习题1
  13. JAVA布局管理器
  14. HDOJ 4862 Jump
  15. python 列表常用方法
  16. Spring整合quart初识
  17. Oracle授权
  18. Spark源码编译,官网学习
  19. lerna import &amp;&amp; add 使用&amp;&amp;常见问题解决
  20. asp.net简述MVC开发模式

热门文章

  1. [转]聊聊技术选型 - Angular2 vs Vue2
  2. 织梦(Dedecms)V5.6 远程文件删除漏洞
  3. UVA 10012 How Big Is It?(暴力枚举)
  4. (LeetCode 86)Partition List
  5. cpu访址能力和内存
  6. STL - 容器 - List
  7. Python面向对象编程 - 一个记事本程序范例(二)
  8. jansson的使用
  9. Java从零开始学三十二(正则表达式)
  10. Spring Boot 中 Controller 使用