另外一个FAQ:https://github.com/SeleniumHQ/selenium/wiki/Frequently-Asked-Questions

8.1.怎样使用ChromeDriver

chromedriver 下载页下载版(译者注:需翻墙)。解压压缩包:

unzip chromedriver_linux32_x.x.x.x.zip

你应该看到一个chromedriver可执行文件。接着你就可以像下面这样创建一个WebDriver实例:

driver = webdriver.Chrome(executable_path="/path/to/chromedriver")

示例的其他部分参考其他文档中的介绍。

8.2.Selenium2支持XPATH2.0吗?

参考:http://seleniumhq.org/docs/03_webdriver.html#how-xpath-works-in-webdriver

Selenium使用的XPath取决于浏览器本身的XPath引擎。也就是说你使用的浏览器支持什么版本的XPath,Selenium就支持什么版本的XPath。如果使用不自带XPath引擎的浏览器(比如,IE5,7,8),Selenium将只支持XPath1.0。

8.3.怎样滚动到页面底部?

参考:http://blog.varunin.com/2011/08/scrolling-on-pages-using-selenium.html

你可以在加载页面的时候使用execute_script方法执行javascript代码。所以,你可以调用Javascript API滚动到页面的底部或其他任意位置。

下面是滚动到页面底部的示例:

driver.execute_script("window.scrollTo(0, document.body.scrollHeight);")

DOM中的window对象有一个scroll方法,用来滚动到窗口的任意位置。scrollHeight是所有元素的一个通用属性。document.body.scrollHeight标识页面整个body的高度。

8.4.怎样使用地址的火狐配置文件自动保存文件?

参考-1:http://stackoverflow.com/questions/1176348/access-to-file-download-dialog-in-firefox

参考-2:http://blog.codecentric.de/en/2010/07/file-downloads-with-selenium-mission-impossible/

首先先识别你要保存的文件的文件类型。

要识别你要自动下载的文件的content-type,可以使用curl+grep命令:

curl -I URL | grep "Content-Type"

另外一种办法是使用requests模块来找到content-type,简单示例如下:

import requests
content_type = requests.head('http://www.python.org').headers['content-type']
print(content_type)

识别出content-type之后,你就可以使用它来设置火狐配置文件的配置:

browser.helperApps.neverAsk.saveToDisk

下面是一个小示例:

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()

在上面的示例中,content-type被设置为 application/octet-stream

browser.download.dir选项用来指定你想要将下载的文件保存的目录。

8.5.怎样通过file input上传文件?

选取<input type="file">元素,调用send_keys方法,给其传递一个文件路径(绝对路径和相对路径均可)。但是请注意Windows系统和Unix系统路径名称的差异。

8.6.怎样在火狐的Firefox?

首先下载FireBug XPI文件,接着你就可以调用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") #避免启动界面
browser = webdriver.Firefox(firefox_profile=fp)

8.7.怎样对当前窗口截图?

使用web'driver提供的save_screenshot方法:

rom selenium import webdriver

driver = webdriver.Firefox()
driver.get('http://www.python.org/')
driver.save_screenshot('screenshot.png')
driver.quit()

[译]Selenium Python文档:八、附录:FAQ常见问题的更多相关文章

  1. [译]Selenium Python文档:目录

    作者:Baiju Muthukadan 协议:本文档采用知识共享署名 - 共享4.0国际许可. 原英文网址:http://selenium-python.readthedocs.io/index.ht ...

  2. [译]Selenium Python文档:一、安装

    1.1.简介 Selenium Python为使用Selenium WebDriver来编写功能/验证测试提供了一个简单的API接口.通过Selenium Python API,你可以以一种非常直观的 ...

  3. [译]Selenium Python文档:四、元素定位

    要定位一个页面中的元素有多中策略和方法.你可以根据实际情况选择其中最为合适的.Selenium为定位页面元素提供了下面的这些方法: find_element_by_id(使用id) find_elem ...

  4. [译]Selenium Python文档:七、WebDriver API接口

    由于API文档格式不太适合cnblog博客,暂且翻译一部分,且暂未校对 注意:这不是官方文档,官方 API文档在这里. 本章包含Selenium WebDriver的所有接口 推荐import风格 本 ...

  5. [译]Selenium Python文档:二、初步开始

    2.1.简单使用 如果已经安装好了Selenium Python,你就可以像下面这样编写Python代码来使用它了: from selenium import webdriver from selen ...

  6. [译]Selenium Python文档:五、Waits等待

    大多数现代web应用都使用了AJAX技术.当浏览器加载一个页面的时候,该页面内的元素可能在不用的时间间隔内进行加载.这使得元素定位变得比较困难:如果一个元素还没有出现在DOM中,定位函数将会抛出一个E ...

  7. [译]Selenium Python文档:六、页面对象

    本章是介绍页面对象设计模式的教程.一个页面对象代表了web应用用户接口的一片区域,你的测试代码将与之交互的. 使用页面对象模式的好处: 可以创建在多个测试样例中都可使用的可重用代码 减少重复性代码 如 ...

  8. [译]Selenium Python文档:三、导航控制

    你使用WebDriver要做的第一件事就是访问一个链接.一般通过调用get方法来实现: driver.get("http://www.baidu.com") 在将控制权返给你的脚本 ...

  9. 基于 Python 官方 GitHub 构建 Python 文档

    最近在学 Python,所以总是在看 Python 的官方文档, https://docs.python.org/2/ 因为祖传基因的影响,我总是喜欢把这些文档保存到本地,不过 Python 的文档实 ...

随机推荐

  1. Sublime Text 中文乱码解决方案

    1.到这里下载安装PackageControl https://packagecontrol.io/installation#Manual 完成重启Sublime Text: 2.按Ctrl+Shif ...

  2. 深入浅出妙用 Javascript 中 apply、call、bind

    这篇文章实在是很难下笔,因为网上相关文章不胜枚举. 巧合的是前些天看到阮老师的一篇文章的一句话: "对我来说,博客首先是一种知识管理工具,其次才是传播工具.我的技术文章,主要用来整理我还不懂 ...

  3. js设置、获取、清除cookie

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="utf-8&quo ...

  4. 基于ES6模块标准通过webpack打包HTM5项目

    本篇主要演示通过webpack打包phaser项目,webpack安装方法在此处就不一一赘述了 经常用phaser来写html5游戏的朋友可能会发现,当游戏场景比较多时,如果都写在一个js文件中那么将 ...

  5. Tcl/tk缩放Truetype字体时的精度问题

    最近有国内新客户抱怨我们产品显示的原理图太不专业了,在原理图上使用宋体GB2312设计好中文图表,经过几次缩放时,表格内的文字居然会跑到表格外边,更要命的是打印出来的文档也存在同样的问题. 我研究了一 ...

  6. Java 同步容器和并发容器

      同步容器(在并发下进行迭代的读和写时并不是线程安全的)   Vector.Stack.HashTable   Collections类的静态工厂方法创建的类(如Collections.synchr ...

  7. 轻松理解python中的闭包和装饰器 (下)

    在 上篇 我们讲了python将函数做为返回值和闭包的概念,下面我们继续讲解函数做参数和装饰器,这个功能相当方便实用,可以极大地简化代码,就让我们go on吧! 能接受函数做参数的函数我们称之为高阶函 ...

  8. 【转】Jqgrid学习之ColModel API

    ColModel 是jqGrid里最重要的一个属性,设置表格列的属性. 属性 数据类型 备注 默认值 align string left, center, right. left classes st ...

  9. 微软MSBI商业智能视频

    第一讲:BI介质安装.BI基础知识讲解.BI方法论讲解.项目讲解                 1.BI基础知识讲解.BI方法论实施2.微软BI的介绍(数据仓库介绍.SSIS介绍.SSAS介绍.SS ...

  10. 【2017-02-26】String类、Math类、DateTime类

    一.String类 黑色小扳手 - 属性     后面不带括号紫色立方体 - 方法     后面带括号 字符串.Length  -  字符串长度,返回int类型 字符串.TrimStart() - 去 ...