网页下载不了软件驱动是怎么回事(为什么下载驱动软件打不开)网页下载不了软件驱动是怎么回事(为什么下载驱动软件打不开)

关注健康
关注真实体验

网页下载不了软件驱动是怎么回事(为什么下载驱动软件打不开)

网页下载不了软件驱动是怎么回事(为什么下载驱动软件打不开)

要做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编辑器为例:

在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版本并解压

# 好吧,这个命令是给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吗?

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

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

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

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


curl -I URL | grep "Content-Type"

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

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

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

这是例子:

import osfrom selenium import webdriverfp = 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 webdriverfp = webdriver.FirefoxProfile()fp.add_extension(extension='firebug-1.8.4.xpi')fp.set_preference("extensions.firebug.currentVersion", "1.8.4") #Avoid startup screenbrowser = webdriver.Firefox(firefox_profile=fp)怎么截图呢?

用webdriver提供的 save_screenshot 方法:

from selenium import webdriverdriver = webdriver.Firefox()driver.get('http://www.python.org/')driver.save_screenshot('screenshot.png')driver.quit()如何使用默认已存在的profile启动firefox?by 乙醇

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


fp = webdriver.FirefoxProfile('/path/to/your/existing/profile')browser = webdriver.Firefox(fp)

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

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

希望本文对你有所帮助~~如果对软件测试、接口测试、自动化测试、面试经验交流感兴趣可以私聊我或关注公众号“特斯汀软件测试”。免费领取最新软件测试大厂面试资料和Python自动化、接口、框架搭建学习资料!技术大牛解惑答疑,同行一起交流。

未经允许不得转载: 九月健康网» 网页下载不了软件驱动是怎么回事(为什么下载驱动软件打不开)
分享到: 更多 ( 0)