本文实例为大家分享了python实现淘宝秒杀脚本的具体代码,供大家参考,具体内容如下
1.安装pycharm。网上教程很多。
2.安装 selenium 库。
selenium支持很多浏览器,我选择的是firefox浏览器。
因为我这里是python3环境,自带的又pip,所以安装selenium直接使用pip安装
安装方法:
--打开cmd;
--输入命令进入python36/scripts(找到下图的目录)目录下;
--输入命令 pip install selenium;
--回车,等待自动安装;
--当最后一行代码出现successfully install selenium-xx时,表示安装成功。
3.插件 firebug
firebug 是火狐浏览器的一款查看代码元素的插件,可以快速的定位元素,selenium的重点就是元素定位,只有定到位了,才能进行下一步操作。
安装方法:
--打开firefox浏览器,点击右上角按钮
--点击附加组件
--点击扩展
--搜索firebug
--点击安装,重启浏览器
--测试安装成功,按f12出现如下画面,表示firebug已经安装成功了
4.安装 驱动安装 geckodriver(windows环境下)
文件链接在下方。
使用方法:
1、下载完成解压;
2、将 geckodriver 放到 该浏览器可执行文件的路径下
3、添加到环境变量中
5. 设置 pycharm
先创建一个工程
打开 pycharm -> 打开 file -> 点击 setting -> 点击最右边的设置按钮
点击 add, 在 virtualenv environment 和 system interpreter 并选定找到本文给的 python 运行文件夹,location 是自己建立的工作文件夹,里面为空,参考操作如下:
打开 pycharm -> 打开 file -> 点击 setting
将 project interpreter 设置为 本文给的文件,或是自己本身的 python自带运行库
6. 新建一个python文件
输入以下程序:
1
2
3
4
|
# -*- coding: utf-8 -*- from selenium import webdriver driver = webdriver.firefox() driver.get(https: / / www.baidu.com) |
得到如下:
则成功搭建好环境。
7. 淘宝秒杀程序
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
|
#!/usr/bin/env python # -*- coding: utf-8 -*- # 2018/09/05 # 淘宝秒杀脚本,扫码登录版 import os from selenium import webdriver import datetime import time from os import path from selenium.webdriver.common.action_chains import actionchains d = path.dirname(__file__) abspath = path.abspath(d) driver = webdriver.firefox() driver.maximize_window() def login(): # 打开淘宝登录页,并进行扫码登录 driver.get( "https://www.taobao.com" ) time.sleep( 3 ) if driver.find_element_by_link_text( "亲,请登录" ): driver.find_element_by_link_text( "亲,请登录" ).click() print ( "请在30秒内完成扫码" ) time.sleep( 30 ) driver.get( "https://cart.taobao.com/cart.htm" ) time.sleep( 3 ) # 点击购物车里全选按钮 # if driver.find_element_by_id("j_checkbox_939775250537"): # driver.find_element_by_id("j_checkbox_939775250537").click() # if driver.find_element_by_id("j_checkbox_939558169627"): # driver.find_element_by_id("j_checkbox_939558169627").click() if driver.find_element_by_id( "j_selectall1" ): driver.find_element_by_id( "j_selectall1" ).click() now = datetime.datetime.now() print ( 'login success:' , now.strftime( '%y-%m-%d %h:%m:%s' )) def buy(buytime): while true: now = datetime.datetime.now().strftime( '%y-%m-%d %h:%m:%s.%f' ) # 对比时间,时间到的话就点击结算 if now > buytime: try : # 点击结算按钮 if driver.find_element_by_id( "j_go" ): driver.find_element_by_id( "j_go" ).click() driver.find_element_by_link_text( '提交订单' ).click() except : time.sleep( 0.1 ) print (now) time.sleep( 0.1 ) if __name__ = = "__main__" : # times = input("请输入抢购时间:") # 时间格式:"2018-09-06 11:20:00.000000" login() buy( "2018-10-22 18:55:00.000000" ) |
以上程序是参照对应的 html 源码的对应元素所选择的。举例如下:
中对应的 j_selectall1 对应如下:
关于 selenium 和 html 源码的交互以后有时间再来研究。
资料链接如下:链接地址
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持服务器之家。
原文链接:https://blog.csdn.net/hc372893308/article/details/83305136