在网页上下载文件时,通常需要人为设定下载文件并选择保持路径,这样就无法实现完全自动的下载过程。下面实现基于firefox浏览器的全自动化文件下载操作:

#encoding=utf-8
from selenium import webdriver
import unittest, time class TestDemo(unittest.TestCase): def setUp(self):
# 创建一个FirefoxProfile实例,用于存放自定义配置
profile = webdriver.FirefoxProfile() #chrome是另外的设置方法
# 指定下载路径,默认只会自动创建一级目录,如果指定了
# 多级不存在的目录,将会下载到默认路径
profile.set_preference('browser.download.dir', 'd:\\iDownload')
# 将browser.download.folderList设置为2,表示将文件下载到指定路径
# 设置成2表示使用自定义下载路径;
# 设置成0表示下载到桌面;设置成1表示下载到默认路径
profile.set_preference('browser.download.folderList', 2)
# browser.helperApps.alwaysAsk.force对于未知的 MIME 类型文件会弹出窗口
# 让用户处理,默认值为true,设定为False表示不会记录打开未知 MIME 类型
# 文件的方式
profile.set_preference("browser.helperApps.alwaysAsk.force", False)
# 在开始下载时是否显示下载管理器
profile.set_preference('browser.download.manager.showWhenStarting',\
False)
# 设定为 False 会把下载框进行隐藏
profile.set_preference("browser.download.manager.useWindow", False)
# 默认值为 true,设定为 False 表示不获取焦点
profile.set_preference("browser.download.manager. focusWhenStarting",\
False)
# 下载.exe文件弹出警告,默认值是 true,设定为False 则不会弹出警告框
profile.set_preference("browser.download.manager.alertOnEXEOpen",\
False)
# browser.helperApps.neverAsk.openFile表示直接打开下载文件,不显示确认框
# 默认值为空字符串,下行代码行设定了多种文件的 MIME类型,
# 例如application/exe,表示.exe类型的文件,
# application/excel表示 Excel 类型的文件
profile.set_preference("browser.helperApps.neverAsk.openFile", \
"application/pdf")
# 对所给出文件类型不再弹出框进行询问,直接保存到本地磁盘
profile.set_preference('browser.helperApps.neverAsk.saveToDisk', \
'application/zip, application/octet-stream')
# browser.download.manager.showAlertOnComplete设定下载文件结束后是否显示下
#载完成提示框,默认为true,设定为False表示下载完成后不显示下载完成提示框
profile.set_preference("browser.download.manager. showAlertOnComplete",\
False);
# browser.download.manager.closeWhenDone设定下载结束后是否自动
# 关闭下载框,默认值为true,设定为False 表示不关闭下载管理器
profile.set_preference("browser.download.manager.closeWhenDone",\
False) # self.driver = webdriver.Ie(executable_path="c:\\IEDriverServer")
# 启动浏览器时,通过firefox_profile参数
# 将自动以配置添加到FirefoxProfile对象中
self.driver = webdriver.Firefox(executable_path="e:\\geckodriver",\
firefox_profile = profile) def test_dataPicker(self):
# 访问WebDriver驱动Firefox的驱动文件下载网址
url1 = "https://github.com/mozilla/geckodriver/releases"
self.driver.get(url1)
# 选择下载zip类型文件,使用application/zip指代此类型文件
self.driver.find_element_by_xpath\
('//strong[.="geckodriver-v0.19.1-arm7hf.tar.gz"]').click()
# 等待加载下载文件
time.sleep(10) # 访问Python2.7.12文件下载页面,下载扩展名为msi文件
# 使用application/octet-stream来指明此类文件类型
url = "https://www.python.org/downloads/release/python-2712/"
self.driver.get(url)
# 找到Python2.7.12下载页面中链接文字为“Windows x86-64 MSI installer”
# 的链接页面元素,点击进行无人工干预的下载Python2.7.12解释器文件
self.driver.find_element_by_link_text\
("Windows x86-64 MSI installer").click()
# 等待文件下载完成,根据各自的网络带宽情况设定等待相应的时间
time.sleep(100) def tearDown(self):
self.driver.quit() if __name__ == '__main__':
unittest.main()

webdriver高级应用- 无人工干预地自动下载某个文件的更多相关文章

  1. selenium3 无人工干预地自动下载某个文件

    一:主要内容 下载效果展示 代码内容展示 saveToDisk不生效说明,即文件没有下载下来解决办法 二:展示效果 1.下载效果展示 用selenium3无人工干预的自动下载该文件到指定路径下,如:D ...

  2. webdriver高级应用- 无人工干预地自动上传附件

    方法一:使用webdriver的send_keys方法上传文件,代码如下: #encoding=utf-8 from selenium import webdriver import unittest ...

  3. IDM下载器添加支持自动下载的文件类型

    不知道各位读者老爷有没有试过IDM下载器的自动下载功能,对于经常需要下载素材资源的朋友来说,一个个的选择图片或者其他什么素材来下载也是够烦的,IDM的自动下载功能可谓是十分好用,而且自动下载+批量下载 ...

  4. webdriver高级应用- 使用Chrome浏览器自动将文件下载到指定路径

    #encoding=utf-8 from selenium import webdriver import unittest, time class TestDemo(unittest.TestCas ...

  5. 【转】Python编程: 多个PDF文件合并以及网页上自动下载PDF文件

    1. 多个PDF文件合并1.1 需求描述有时候,我们下载了多个PDF文件, 但希望能把它们合并成一个PDF文件.例如:你下载的数个PDF文件资料或者电子发票,你可以使用python程序合并成一个PDF ...

  6. C# 利用FTP自动下载xml文件后利用 FileSystemWatcher 监控目录下文件变化并自动更新数据库

    using FtpLib; using System; using System.Collections.Generic; using System.ComponentModel; using Sys ...

  7. yandex 图片自动下载

    yandex 图片自动下载命令行程序 一个在 yandex 上搜索图片并下载到本地的 node cli 程序. 使用帮助: $0 <搜索关键词> [-t=超时(默认 1000)] [-r ...

  8. 【转】Java生成plist下载ipa文件

    我们在上传ipa想要安装的时候必须要通过plist文件去下载,并且还要遵循 itms-services协议. 意思就是,第一步我们要生成一个plist文件, 第二步生成一个html文件,用来指向pli ...

  9. python使用selenium,webdriver自动下载百度网盘内容

    想实现一个自动下载微信公众号分享百度网盘图片链接的爬虫,使用selenium和火狐的webdriver进行完成 1.首先根据自己的浏览器下载相应的webdriver驱动器,python中导入selen ...

随机推荐

  1. ZR#331. 【18 提高 3】括号序列(栈)

    题意 挺神仙的.首先$60$分暴力是比较好打的. 就是枚举左端点,看右端点能否是$0$ 但是这样肯定是过不了的,假如我们只枚举一次,把得到的栈记录下来 那么若区间$(l, r)$是可行的,那么$s_{ ...

  2. JavaScript中var a=b=c=d的发现

    看了别人的博客随手记录下 先看一下以下的代码 var a=1,b=2,c=3; (function(){ var a=b=1; })(); console.log(a); console.log(b) ...

  3. css hack 浏览器携带自身特有的属性 (二)

    css hack 浏览器携带自身特有的属性,才是我们真正要解决的css 兼容问题. 这里只是分享思路. 举例子: 1 outline,尤其是一些 自带继承特性的属性.这里指的是 隐性的inherite ...

  4. C# List的使用

    1.所需引入的命名空间: using System.Collections.Generic; 2.初始化 [1]空: List<int> list = new List<int> ...

  5. Elasticsearch-基本操作1

    Elasticsearch版本:6.0 一.文档 一个文档不仅包含数据,也包含元数据,三个必须的元数据如下 _index:具有共同特性分到一起的文档集合,标示了文档的存放位置: 名字小写,不以下划线开 ...

  6. sessionStorage 详解,特点,使用技巧,场景

    很早之前久知道sessionStorage ,也学习过,但没有实战使用过 .最近团队遇到一个问题<electronjs中打开新页面sessionStorage丢失>,让我有机会重新来认识一 ...

  7. 发现知乎的一个Bug,并且我绕过了此Bug,沾沾自喜中...

    发现问题 在知乎点击修改头像,上传图片时发现一片空白.凭着程序员的直觉,第一反应时看下控制台是否有报错.果然发现如下: Refused to load the image 'data:image/jp ...

  8. freespace

    这是一个总结freespace的博客,还不错,但算法目前看来比较老:https://blog.csdn.net/u010213183/article/details/70786516

  9. 字符编码:WideCharToMultiByte

    WideCharToMultiByte 编辑   目录 1基本介绍及功能 2相关变量     1基本介绍及功能编辑 WideCharToMultiByte 函数功能:该函数映射一个unicode字符串 ...

  10. 虚拟机设置NAT

    需要开启虚拟机网络相关服务, 安装虚拟网卡, 还有必须安装 VMware Tools VMware虚拟机下实现NAT方式上网1. 把你的虚拟网卡VMnet8设置为自动获得IP.自动获得DNS服务器,启 ...