python+selenium:引入包、调用库方法失败、(附常见问题列表)

要做web自动化,第一件事情就是搭建自动化测试环境,那就没法避免地要用到selenium了。

那在搭建环境和使用过程中经常会遇到以下几类问题:

1、引入selenium包失败:

出现这种错误,一般分为两种情况:

1、根本没有安装selenium库;

2、安装了selenium库,可是在导入的时候,仍然提示selenium库不存在。

解决方法:

针对第1种,那就是麻溜地去安装selenium库。pip命令安装最好!!命令:pip install selenium

针对2:

1)确认你安装的selenium第三方库安装在哪个python目录中?并确认你的selenium安装成功;

如何确认?安装的时候,会直接输出你的selenium安装到了哪里。注意观察哟。

2)确认你的代码使用的python是哪个,安装目录在哪里?是否是1)中对应的python目录。

在pycharm当中, 每一个project都会有一个External Libraries栏。如下图:

会直接显示你当前project所用的python版本以及安装目录;

打开其下的site-packages目录,会显示所有安装的第三方库。如果能够找到selenium文件夹,则说是在这个python版本中是安装了selenium的

注意注意:pycharm现在有专业版和 区版。很多新手朋友们去用破解版的专业版,结果入了坑也不知道。

因为专业版是默认使用的 – 它给你创建的虚拟环境的。你需要手动配置成使用系统python环境 。所以高度建议,新手们使用 区版就好。

如果以上两点,都确认无误,没错,就是安装在我当前正在用的python当中。那恭喜你,可以正常引入selenium的webdriver包了。

2、调用selenium库方法失败:Module object is not callable

这个问题就好解决了。。。

就是使用webdriver的功能时,把功能名字给错了。你一写错,人家webdriver库根本就找不到这个名字对应的功能。自然就 了上面的错误 。

所以,正确的方式是:

browser = webdriver.Chrome()

3、浏览器版本与驱动版本不匹配的 错: call function result missing ‘value’

这个问题就要从selenium环境安装方面说起了。

我们功能测试测web系统时,就是通过人工去在浏览器页面中各种点点点。但是自动化,咱们得换个实现方式了。

是通过代码来自动地去浏览器页面中各种点点点。即 python+selenium代码 与 浏览器 进行交互。

而且浏览器这个物种有多种类型,谷歌、ie、firefox、safaria……

两个完全不同的物种如何交流??

翻译!!中间件!! 没错,就是它了。。。为了解决这个问题,浏览器厂商提供各种的驱动软件。于是就有了chromedrver,IEdriver,geckodriver……

驱动软件可以跟我们的python+selenium自动化代码交互,也可以跟浏览器进行交互。把自动化代码要做的事情,通过驱动软件去驱动浏览器操作实现。

但是,软件从生出开始,就需要不断的长大、进化,更好的为人民服务。

所以浏览器会不断地更新,那么与其匹配的驱动软件也会同样的更新。

所以就会有:不同的驱动版本,支持不同的浏览器版本。

so,这样的 错解决方法就是:去下载匹配你当前浏览器版本的驱动。

放在你所用python版本的安装目录下面。

python selenium webdriver 常见问题FAQ

怎么用ChromeDriver ?

从这里下载最新的driver版本并解压


你会得到一个 chromedriver 的可执行文件. 现在用下面的代码就可以了:


Selenium 2支持XPath 2.0吗?

Selenium把xpath处理委托给了浏览器的xpath解析引擎。所以浏览器支持什么,selenium就支持什么。如果那些奇葩的浏览器没有xpath引擎的话(IE6,7,8),那么在这些大爷上selenium就只支持xpath1.0了

怎样才能滚到页面的底部?

你可以用 execute_script方法来处理这个。 调用原生javascript的API,这样你想滚到哪里就能滚到哪里。

下面的代码演示了如何滚到页面的最下面:


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来自动保存下载的文件

首先,你要保存的文件类型你造么?
要搞清楚要自动下载的文件类型,用 curl就好了


另一种方式是使用 requests <
http://python-requests.org>_ module, 这样搞:


当你确定了content type之后,调用
browser.helperApps.neverAsk.saveToDisk来设置firefox的profile就好了。

这是例子:


上例中, application/octet-stream 就是content type。

browser.download.dir 指定了文件自动保存的文件夹。

如何在打开Firefox的同时打开firebug ?

首先下载Firebug XPI文件(这个就是friefox的扩展程序文件–by乙醇),然后再调用firefox profile的add_extension方法。


怎么截图呢?

用webdriver提供的 save_screenshot 方法:


如何使用默认已存在的profile启动firefox?by 乙醇

使用已存在profile启动firefox可以自动登陆已经登陆过的站点。代码如下:


这里在windows上有个坑,就是路径分隔符在windows上是而不是/,把这个弄明白然后指定对路径基本就可以了。

PS:这里还有另一个坑。就是如果你使用默认的profile的话,请一定关闭friefox以后再运行代码,否则会因为profile的文件锁问题而发生异常。就是说一次只能打开一个firefox实例,如果你使用默认的profile的话。

声明:本站部分文章及图片源自用户投稿,如本站任何资料有侵权请您尽早请联系jinwei@zod.com.cn进行处理,非常感谢!

上一篇 2022年5月1日
下一篇 2022年5月1日

相关推荐