右键另存下载文件

先编辑SciTE脚本:

;ControlFocus("title","text",controlID)

;表示将焦点切换到标题为title窗体中的controlID上

;Edit1表示第一个可以编辑的实例

;title表示弹出的Window窗口标题,不同浏览器的标题可能不一样

ControlFocus("请输入要保存的文件名...","","Edit1")

;等待10秒以便window窗口加载成功

WinWait("[CLASS:#32770]","",10)

;将焦点切换到Edit1输入框中

ControlFocus("另存为","","Edit1")

;等待2秒

Sleep(2000)

;将要下载的文件名及路径写入Edit1编辑框中

ControlSetText("另存为","", "Edit1", "d:\iDownload\Firefox Setup 35.0b8.exe")

Sleep(2000)

;点击窗体中的第一个按钮,也就是保存按钮

;ControlClick("另存为","","Button1")

Send("{ENTER}")

Send("{ENTER}")

;保存后将该文件编译成exe文件,并存放到本地磁盘。

;保存后将该文件编译成exe文件,并存放到本地磁盘

然后保存成SciScript,然后用convert工具转成exe文件

执行python程序,修改相关目录

# encoding=utf-8

from selenium import webdriver

import unittest, time, os

from selenium.webdriver.common.keys import Keys

from selenium.webdriver import ActionChains

import win32api

import win32con

VK_CODE ={'enter':0x0D, 'down_arrow':0x28}

#键盘键按下

def keyDown(keyName):

win32api.keybd_event(VK_CODE[keyName], 0, 0, 0)

#键盘键抬起

def keyUp(keyName):

win32api.keybd_event(VK_CODE[keyName], 0, win32con.KEYEVENTF_KEYUP, 0)

class TestDemo(unittest.TestCase):

def setUp(self):

#self.driver = webdriver.Ie(executable_path = "e:\\IEDriverServer")

self.driver = webdriver.Chrome(executable_path="c:\\chromedriver")

def test_dataPickerByRightKey(self):

# 定义将要访问的网址

url = "http://ftp.mozilla.org/pub/mozilla.org//firefox/releases/35.0b8/win32/zh-CN/"

self.driver.get(url)

# 将窗口最大化

self.driver.maximize_window()

# 暂停5秒,目的防止页面有一些多余的弹窗占据焦点

time.sleep(5)

# 找到文本内容为“Firefox Setup 35.0b8.exe”超链接元素

a = self.driver.find_element_by_link_text("Firefox Setup 35.0b8.exe")

time.sleep(2)

# 在找到的链接元素上模拟点击鼠标右键,

# 以便调出选择“另存为”选项的菜单

ActionChains(self.driver).context_click(a).perform()

# 暂停2秒,防止命令执行太快

time.sleep(2)

for i in range(4):

# 循环按4次下箭头,将焦点切换到“另存为”选项上

# 不同浏览器此选项的位置可能不同

#a.send_keys(Keys.DOWN)

keyDown("down_arrow")

keyUp("down_arrow")

print i

time.sleep(2)

time.sleep(2)

# 当焦点切换到“另存为”选项上后,模拟点击回车键

# 调出保存下载文件路径的Windows窗体

keyDown("enter")

keyUp("enter")

time.sleep(3)

# 通过执行AutoIt编写的操作弹窗的Windows文件保存窗体

# 完成文件保存路径的设置

os.system("d:\\test\\rightClick.exe")

# 等待文件下载完成,根据各自的网络带宽情况设定等待相应的时间

time.sleep(5)

#def tearDown(self):

#self.driver.quit()

if __name__ == '__main__':

unittest.main()

D:\test>python test.py

DevTools listening on ws://127.0.0.1:12860/devtools/browser/c68d0424-6626-421d-8268-3184f78ede57

0

1

2

3

.

----------------------------------------------------------------------

Ran 1 test in 46.308s

OK

python webdriver api-右键另存下载文件的更多相关文章

  1. rest api上传和下载文件

    rest api上传和下载文件 function FileToString(AFileName: string): string; var LMemoryStream: TMemoryStream; ...

  2. 转:python webdriver API 之下载文件

    webdriver 允许我们设置默认的文件下载路径.也就是说文件会自动下载并且存在设置的那个目录中.要想下载文件,首选要先确定你所要下载的文件的类型.要识别自动文件的下载类型可以使用 curl ,如图 ...

  3. python WebDriver如何处理右键菜单

    WebDriver如何处理右键菜单 一.背景 在学习selenium webdriver的过程中,遇到这样一个问题.ActionChains类中提供了context_click的方法,它可以用来在we ...

  4. 转:python webdriver API 之操作测试对象

    一般来说,所有有趣的操作与页面交互都将通过 WebElement 接口,包括上一节中介绍的对象定位,以及本节中需要介绍的常对象操作.webdriver 中比较常用的操作元素的方法有下面几个: cle ...

  5. 转:python webdriver API 之简单对象的定位

    对象(元素)的定位和操作是自动化测试的核心部分,其中操作又是建立在定位的基础上的,因此元素定位就显得非常重要. (本书中用到的对象与元素同为一个事物)一个对象就像是一个人,他会有各种的特征(属性) , ...

  6. python网络爬虫之使用scrapy下载文件

    前面介绍了ImagesPipeline用于下载图片,Scrapy还提供了FilesPipeline用与文件下载.和之前的ImagesPipeline一样,FilesPipeline使用时只需要通过it ...

  7. 初级版python登录验证,上传下载文件加MD5文件校验

    服务器端程序 import socket import json import struct import hashlib import os def md5_code(usr, pwd): ret ...

  8. python网络编程-socket上传下载文件(包括md5验证,大数据发送,粘包处理)

    ftp server 1) 读取文件名 2)检查文件是否存在 3)打开文件 4)检查文件大小 5)发送文件大小给客户端 6)等客户端确认 7)开始边读边(md5计算)发数据 8)给客户端发md5 ft ...

  9. 转:python webdriver API 之上传文件

    文件上传操作也比较常见功能之一,上传功能操作 webdriver 并没有提供对应的方法,关键上传文件的思路.上传过程一般要打开一个系统的 window 窗口,从窗口选择本地文件添加.所以,一般会卡在如 ...

随机推荐

  1. 利用 :first-child 和 :nth-last-child 确定子元素数目

    读<css揭秘>时,发现选择器的神奇作用,可以确定子元素数目,比如: li:first-child:nth-last-child(2),li:first-child:nth-last-ch ...

  2. Kendo UI使用小小记

    之所以说小小记,是因为我根本没有好好用它,只是正好前些日子接触了一下,觉得还不错,随手记记~ 契机 我从加入现在这个公司以来,半专业的承担了很多前端相关的事情,用过不少前端框架,也为框架和原生的页面写 ...

  3. 力推:无限制下载神器aria2

    百度网盘是一个非常方便的存储以及寻找资源的好帮手,但是百度为了挣钱把非会员的下载网速一再限制(无力吐槽),还还好一直使用油猴插件加idm下载神器来下载百度云文件.奈何idm对bt种子文件不支持下载,终 ...

  4. ubuntu安装Anaconda2-4.4.0+TensorFlow

    1.下载Anaconda 到官网http://continuum.io/downloads下载anaconda. 2.安装anaconda 在终端输入:cd ~/Downloads;        b ...

  5. Python3.6.3中,functools似乎不能用

    用pip install安装时报编码错误: return s.decode(sys.__stdout__.encoding) UnicodeDecodeError: 'utf-8' codec can ...

  6. Wireless Network--poj2236(并查集)

    Description An earthquake takes place in Southeast Asia. The ACM (Asia Cooperated Medical team) have ...

  7. MySQL事务隔离级别详解(转)

    原文: http://xm-king.iteye.com/blog/770721 SQL标准对事务定义了4种隔离级别,包括了一些具体规则,用来限定事务内外的哪些改变是可见的,哪些是不可见的.低级别的隔 ...

  8. 【Python】web.py-简单轻量级网页框架python

    简单轻量级网页框架python web.py的安装 python 3.x中安装web.py 最近决定从python2.7转移到3.x上工作. 使用数据库的时候,依然选用了之前比较感兴趣的web.py ...

  9. MySQL找出锁等待

    1.服务器级别的锁等待 可以通过show processlist看到等待锁的线程id,但是无法知道究竟哪个线程持有锁 可以通过mysqladmin debug 相关等待锁的线程以及谁持有锁可以在错误日 ...

  10. http如何301到https呢?

    HTTPS协议的站点信息更加安全,同时可降低网站被劫持的风险,Firefox和chrome浏览器对访问一些非https站点会提示风险,BD等搜索引擎也明确表态了对https站点的友好.那么我们如何部署 ...