目录
前言:
分析(x0)
第一步
第二步
第三步
环境配置
模块安装
selenium的环境配置
Python代码
视频教程
大家好,我叫善念。自从很多关于python爬虫的文章被下架了后,我的博文是越来越没起色了。我想是因为账号的权重被下降的太多了。如果文章对您有所帮助,我希望大家可以帮忙点个一键三连,顺便动动您发财的小手给我来个如实的评论。
关于这个脚本的话,其实是我18年给学员讲的一个小案例。虽然是针对淘宝的,但实际上它是个万能脚本,为什么呢?因为它是selenium写的,所以说基本都是通用的,无非是改一些元素选择即可。
本文包含文章的思路介绍以及源代码提供,并且包含视频教程!
首先咱们以淘宝为例,那么你想要抢购商品,
要做的就是登录账号:
然后呢
大家一定要选择扫码登录:
理由就是淘宝毕竟是淘宝,你正常的模拟输入账号密码是被检测的,有人可能已经尝试过,我可以这样讲吧,如果把账号拆成三段,密码拆成三段,然后加延迟的话确实偶尔可以登录成功!
但是你要知道为什么是偶尔呢?因为淘宝风控的是你的代理包括你的一个机器环境。所以咱们还是老老实实选择扫码登录吧。
肯定好多人会认识是搜商品然后.....其实不是的,关于咱们的一个抢购机制咱们一定要明白,那就是以结算为准以结算为准以结算为准,重要的事情说三遍,
何为结算?
其实就是说你只需要点击到结算按钮即可(即使不结算也没事,只要你点击了结算,系统会提醒你必须多长时间内付款,但实际上这个商品只要你付款就已经属于你,名额已经属于你了)
所以咱们需要做的就是提前手动把需要抢购的商品添加到购物车,然后判断时间,如果到点了,那么脚本立马给我无限点击结算即可!
pip install selenium
time 为内置模块无需安装。
这个东西我讲过无数遍了,没办法 。还是得从以前的文章中复制粘贴过来......
关于selenium这个模块,咱们来重点介绍一下:
Selenium是一个用于Web应用程序测试的工具。Selenium测试直接运行在浏览器中,就像真正的用户在操作一样。
如果不能够理解我就讲点白话,如果你是web开发人员,开发好了几百个网站,那么如果你认为的去一个个的测试BUG,是不是很浪费时间?而selenium这个框架就是用来模拟人去自动化操控浏览器的,那么是不是就节约了很多时间呢。
既然selenium能够操控浏览器,那么它们之间必须要有一个桥梁,总不能无中生有吧?
那么操控的浏览器款式不一样,中间的桥梁也是不一样的。比如我更喜欢用chrome浏览器,那么咱们需要下载一个selenium与Chrome的桥梁——Chromedriver插件
下载地址
下载与你当前谷歌浏览器版本最相近的Chromedriver
那么像我的话,下载 即可。
Windows系统需下载32位,其它的自己看着办。点进去下载win32即可。
那么如何让Python与selenium连接起来呢,这里咱们需要配置一个环境变量,就是把Python与selenium处于同一个目录:
到此为止,咱们的环境就搭建好了。
from selenium import webdriver
import datetime, time
def login():
# 打开淘宝登录页,并经行扫码登录
brower.get("https://www.taobao.com")
# 等待selenium 框架加载网页完成
time.sleep(3)
if brower.find_element_by_link_text("亲,请登录"):
brower.find_element_by_link_text("亲,请登录").click()
input('扫码完成后按一下Enter键')
brower.get("https://cart.taobao.com/cart.htm")
time.sleep(3)
now = datetime.datetime.now()
print('login success: ', now.strftime('%Y-%m-%d %H:%M:%S'))
# 2. 实现商品购买
def buy(times):
# 点击购物车里的全选按钮
while True:
now = datetime.datetime.now().strftime('%Y-%m-%d %H:%M:%S.%f')
# 对比时间,时间到的话就点击结算
if now > times:
while True:
# 异常处理
try:
if brower.find_element_by_id("J_SelectAll2"):
brower.find_element_by_id("J_SelectAll2").click()
break
except:
print('找不到全选按钮...')
# 点击结算按钮//*[@id="J_Go"]/span
while True:
try:
if brower.find_element_by_xpath('//*[@id="J_Go"]/span'):
brower.find_element_by_xpath('//*[@id="J_Go"]/span').click()
print('结算成功')
break
except:
print('找不到结算按钮')
# 提交订单
# while True:
# try:
# if brower.find_element_by_link_text('提交订单'):
# brower.find_element_by_link_text("提交订单").click()
# now1 = datetime.datetime.now().strftime('%Y-%m-%d %H:%M:%S.%f')
# print('抢购成功时间:%s' % now1)
# break
# except:
# print('我的银行卡没钱...')
#
# time.sleep(0.01)#2019-06-09 17:05:00.000000
# 启动函数2019-11-02 14:03:00.000000
if __name__ == "__main__":
times = input("请输入抢购时间,格式(2019-05-08 20:00:00.000000):")
brower = webdriver.Chrome()
login()
buy(times)
来看我用Python抢茅台,万能的抢购软件开发!