前两天,想抢购一个小米MIX,结果,一开始抢就没有了。于是想,作为程序猿,总得有点特殊手段吧,比如说一个小脚本。最近在学习python,百度了一下,发现了Splinter这个强大的东东!用了不到两小时的时间,就可以实现许多令人点赞的功能,真让人很兴奋呐!

首先,官网(https://splinter.readthedocs.io/en/latest/index.html)介绍,一句话,一个开源工具用来通过python自动化测试web,让电脑自动操作网页:

Splinter is an open source tool for testing web applications using Python. It lets you automate browser actions, such as visiting URLs and interacting with their items.

既然可以自动操作网页,当然不局限于自动化测试喽!

第一步,下载Splinter模块和Chrome或FireFox的驱动(就是强大的开源web自动化测试框架selenium的驱动

Splinter模块是python egg,下载当然很简单:pip install splinter

由于基于selenium,所以,FireFox和Chrome的驱动,都依赖于pip install selenium,不过好像执行pip install splinter之后默认就已经安装了,没有的话再安装一下。

我这个用Chrome的驱动chromedriver,注意版本要对应,不然基本上会有unknown error,打不开浏览器!

官网下载地址:https://sites.google.com/a/chromium.org/chromedriver/downloads  当然这里需要可以连接上google!

selenium 3.x开始,webdriver/firefox/webdriver.py的__init__中,executable_path="geckodriver",所以火狐浏览器需要这个驱动!

下载地址:https://github.com/mozilla/geckodriver/releases/

上述驱动也可以在selenium官网中查找并下载:http://docs.seleniumhq.org/download/

下载之后,放在任意目录,配置该目录到系统环境变量的path中,让电脑可以找到即可:
 

这样,Splinter就可以自动打开浏览器,并进行操作了!

另外注意:1. Splinter的Browser类默认优先调用的驱动是firefox,所以用chrome的话需要在初始化Browser时候指定driver_name="chrome"参数,建议都明确指定浏览器!
     2. 如果chrome或者firefox的安装目录不是默认目录,selenium可能会找不到浏览器,此时只要把浏览器的安装路径配置在电脑的path路径中,让selenium可以自动找到即可!
     例如报错:

WebDriverException: Message: Expected browser binary location, but unable to find binary in default location, no 'moz:firefoxOptions.binary' capability provided, and no binary flag set on the command line

第二步,你可以根据官网的例子用python IDLE运行,打开浏览器并进入指定网页,操作网页。

我这边有写了一个自动登录163邮箱的小脚本:
  1) 创建一个Browser实例,就会打开相应的浏览器。
  2) visit(url): 故名思议,访问指定网站
  3) find_by_id("控件的id").first: 根据控件的属性id找到控件,一般控件都有独立唯一的id。不然,Splinter api还提供by_name,by_id,by_tag等方法!first表示返回第一次找到的控件。
  4) fill("要填充的内容"): 用指定的内容填充相应控件
  5) click(): 点击控件   
  6) 登录后,browser.cookies.all()中保存了本次登录的cookie信息(dict类型),可以打印出来或者保存下次使用
7) quit_browser(browser)函数: 要求用户交互输入q再退出。否则,程序跑完之后就直接退出了,释放Browser的实例,调用quit()方法,浏览器也就关闭了。
#coding:utf-8
from splinter import Browser
import time, threading
def qq_mail_login(url=None, username=None, password=None):
with Browser(driver_name="chrome") as browser:
browser.visit(url)
browser.find_by_id(u"userNameIpt").first.fill(username)
browser.find_by_id(u"pwdInput").first.fill(password)
browser.find_by_id("btnSubmit").first.click() for k, v in browser.cookies.all().items():
print (k, ":", v) quit_browser(browser)
def quit_browser(browser=None):
flag = input("Input q when you want to quit: ")
if 'q' == str(flag):
quit(browser) if __name__=='__main__':
url="http://email.163.com/"
username="你的邮箱地址"
password="你的邮箱密码"
#t1 = threading.Thread(target=qq_mail_login,args=(url,username,password))
#t1.start()
#t1.join()
qq_mail_login(url,username,password)

运行效果就是,你什么都不用管,可以自动用指定浏览器打开你的邮箱:

 

第三步,好了,言归正传,splinter这么强大,肯定不仅仅能做用来打开邮箱这么简单事情。下来就想想,怎么用它来抢东西吧!
    于是,对上述代码稍作修改:首先,登录小米官网,登录后,模拟点击去抢购即可。
    在购买界面,J_chooseResultInit控件,是下一步操作的按钮,在货物不足的时候是隐藏的,所以,我这里用一个while循环,每10秒检查一次,一直等待该按钮可用。之后点击进行下一步购买操作:
#coding:utf-8
from splinter import Browser
import time, threading
def qq_mail_login(url=None, username=None, password=None):
with Browser(driver_name="chrome") as browser:
browser.visit(url[0])
#进入登录界面
browser.click_link_by_href("//order.mi.com/site/login?redirectUrl=http://www.mi.com/")
#输入用户名密码,完成登录
browser.find_by_id(u"username").first.fill(username)
browser.find_by_id(u"pwd").first.fill(password)
browser.find_by_id("login-button").first.click()
time.sleep(1)
#进入购买界面
browser.visit(url[1])
#点击购买“下一步”
count = 1
while not browser.is_element_not_present_by_id('J_chooseResultInit'):
print ("第",count,"次: ",browser.is_element_not_present_by_id('J_chooseResultInit'))
time.sleep(10)
count += 1
browser.find_by_id("J_chooseResultInit").first.click()
quit_browser(browser) def quit_browser(browser=None):
flag = input("Input q when you want to quit: ")
if 'q' == str(flag):
quit(browser) if __name__=='__main__':
url=["http://www.mi.com/","http://item.mi.com/buyphone/mix/"]
username="你的用户名"
password="你的密码"
#t1 = threading.Thread(target=qq_mail_login,args=(url,username,password))
#t1.start()
#t1.join()
qq_mail_login(url,username,password)
因为现在只能进入到这个购买界面,也不知道下个界面有什么控件,所以该例子只是为了学习强大的splinter工具包!至少可以做些日常生活中的小工具嘛!
真想做好抢购工作,当然还有一个重要的问题是图片验证码的处理。最理想的是多线程模拟请求发送,不过需要事先抓包构造请求数据,还是比较麻烦的。
不过现在网上都有或多或少的解决方案,感兴趣的话,我会继续研究并持续更新,不过这篇博客还是为了学习为主哦!
玩蛇网有一篇抢购火车票的帖子,我觉得也蛮不错的,可以参考:http://www.iplaypython.com/news/a260.html

Splinter学习——不仅仅是自动化测试哦的更多相关文章

  1. Splinter学习--初探1,模拟百度搜索

    Splinter是以Selenium, PhantomJS 和 zope.testbrowser为基础构建的web自动化测试工具,基本原理同selenium 支持的浏览器包括:Chrome, Fire ...

  2. Splinter学习--初探3,两种方式登录QQ邮箱

    目前,qq邮箱的登录方式有: 1.利用账号.密码登录 2.快捷登录,前提是你本地已有qq账号登录中 和前面一样,还是先到qq邮箱登录首页,审查页面元素,找到我们进行登录操作所相关的链接.按钮或是输入框 ...

  3. Selenium学习笔记(1) - 自动化测试体系与原理

    技术体系 基于代码的测试(Code-Based Testing) 基于协议的测试(Protocol-Based Testing) 基于界面的测试(GUI-Based Testing) 工作原理 基于代 ...

  4. Python学习总结 10 自动化测试Selenium2

    一, 配置 Selenium2 1 Selenium是什么? Selenium是一个用于Web应用程序测试的工具.Selenium 测试直接运行在浏览器中,就像真正的用户在操作一样.支持的浏览器包括I ...

  5. 持续集成学习5 jenkins自动化测试与构建

    一.jenkins参数 1.主要参数类型 2.触发构建参数 3.参数值的使用 4.给git仓库配置参数,让其构建的时候可以选择分支 5.配置password参数 6.添加Choice参数 7.其它好用 ...

  6. 在做自动化测试之前你需要知道的,转自:http://www.cnblogs.com/fnng/p/3653793.html

    什么是自动化测? 做测试好几年了,真正学习和实践自动化测试一年,自我感觉这一个年中收获许多.一直想动笔写一篇文章分享自动化测试实践中的一些经验.终于决定花点时间来做这件事儿. 首先理清自动化测试的概念 ...

  7. 基于python的接口测试学习笔记一(初出茅庐)

    第一次写博客笔记,讲一下近来学习的接口自动化测试.网上查阅了相关资料,最后决定使用python语言写接口测试,使用的是python的第三方库requests.虽然python本身标准库中的 urlli ...

  8. Python3+Selenium2完整的自动化测试实现之旅(五):自动化测试框架、Python面向对象以及POM设计模型简介

    前言 之前的系列博客,陆续学习整理了自动化测试环境的搭建.IE和Chrome浏览器驱动的配置.selenium-webdriver模块封装的元素定位以及控制浏览器.处理警示框.鼠标键盘等方法的使用,这 ...

  9. 浅谈UI自动化测试

    最近一直在学习python,正好部门技术结构调整,就开始了点工向UI自动化测试的转变,我要说瞌睡来了就掉枕头么? 不过还好,可以将python的学习成果在自动化测试中实践... 1.about自动化测 ...

随机推荐

  1. Git中如何利用生成SSH个人公钥访问git仓库

    Git中如何利用生成SSH个人公钥访问git仓库方法(这里以coding平台为例): 1. 获取 SSH 协议地址 在项目的代码页面点击 SSH 切换到 SSH 协议, 获得访问地址, 请使用这个地址 ...

  2. Android Studio JNI 开发简单案例

    转载:http://www.androidchina.net/5744.html 进程保活,热修复,硬件接入等等都需要底层的支持,而底层代码是 C .C++ 写的,那么在 Android 中怎么调用底 ...

  3. 企业站SEO记录

    半个多月前给接了一个企业站,赚点小钱,客户也没什么要求,所以就找了模板修改了一下就上线了,然后又做了微信网站.搭了微信公众号,也都没什么技术含量,最伤脑筋的就是做关键词排名了,虽然做的几个词竞争也不是 ...

  4. LINQ函数

    LINQ函数虽然和LINQ语句实现了同样的功能,但LINQ函数使用起来更加快捷.学过数据库的感觉LINQ语句都不难,但语句比较长. 会LINQ函数,才算会LINQ. 1.Where(),结果过滤 Li ...

  5. 【JavaScript】ArtTemplate个人的使用体验。

    据说ArtTemplate是腾讯的,感觉这东西真不错,使用方便,用起来很简单,哈哈.腾讯也不完全只是坑爹啊. ArtTemplate 使用是,正常引入js,这个自然不用说.这东西啥时候使用呢?我觉得这 ...

  6. 机器学习笔记----Fuzzy c-means(FCM)模糊聚类详解及matlab实现

    前言:这几天一直都在研究模糊聚类.感觉网上的文档都没有一个详细而具体的讲解,正好今天有时间,就来聊一聊模糊聚类. 一:模糊数学 我们大家都知道计算机其实只认识两个数字0,1.我们平时写程序其实也是这样 ...

  7. SQL 同时查看2个表

    1.要想上下查看2个表,一定要2个表显示的字段数量一致,格式一致 2.格式不一致就统一转换为字符串 -- to_char(s.saleid,'999999999') ,-- to_char(s.upd ...

  8. 使用Python解析JSON数据

    使用Python解析百度API返回的JSON格式的数据 # coding:utf-8 # !/usr/bin/env python import matplotlib.pyplot as plt fr ...

  9. OpenStack三种类型的NAT转换

    SNAT SNAT即源网络地址转换,这个NAT路由修改IP包包头中的源IP地址.SNAT功能通常用于让只具有私有IP地址的主机能够访问外网,比如,多个PC使用路由器共享上网,每个PC都配置了内网IP, ...

  10. jQuery 中 jQuery(function(){})与(function(){})(jQuery) 的区别

    $(document).ready(function(){ // 在这里写你的代码... }); 在DOM加载完成时运行的代码 可以简写成 jQuery(function(){ // 在这里写你的代码 ...