京东抢购脚本升级版

环境:python3.7

浏览器:火狐

在python scripts文件夹下边放入相应版本的geckodriver(或手动把geckodriver加入环境变量)

本脚本只适用于可以提前把抢购商品加入购物车的场景(实质是一个定时清空购物车的脚本)

新加特性

  • 增加了隐式等待和拖动滚动轴操作,实现了全自动化
  • 增加了对COOKIE的调用,实现了免密码登录
  • 增加了一些校验,并且优化了程序运行逻辑,进一步提高抢购效率

cmd页面:

pip install selenium
pip install datetime

事先需要把商品放入购物车,电脑时间和北京时间一致

代码实现

  • 首先:project下有三个文件:buy_plus.py;get_cookie.py;cookie_file.txt

操作步骤

(建议至少提前10分钟操作)

  1. 运行get_cookie.py,页面出现登录二维码后进行扫码登录
  2. 修改buy_plus.py中的抢购时间
  3. 至少提前1分钟运行buy_plus.py,等待抢购

buy_plus.py

from selenium import webdriver
import time
import datetime
import json

from selenium.webdriver.common.by import By
from selenium.webdriver.support import expected_conditions
from selenium.webdriver.support.wait import WebDriverWait

class jd_buy_plus():
    def __init__(self, buy_time):
        self.buy_time = buy_time

    def driver(self):
        option = webdriver.FirefoxOptions()
        option.add_argument('-headless')
        self.webdriver = webdriver.Firefox(firefox_options=option) # 使用无头模式提高效率,测试时可取消无头模式,括号为空即可
        self.webdriver.maximize_window()
        self.webdriver.implicitly_wait(5) # 隐式等待
        self.webdriver.get("https://cart.jd.com/cart.action")  # 此为购物车网站

    def cookie(self): # 此方法作用为读取cookie_file.txt文件,并加载cookie
        file = open(r"./cookie_file.txt")
        cookie = file.read()
        cookie = json.loads(cookie)
        for i in cookie:
            self.webdriver.add_cookie(i)
        self.webdriver.refresh()

    def buy_on_time(self): # 主要实现抢购功能方法
        while True:
            now = datetime.datetime.now()
            title = self.webdriver.title
            if now.strftime('%Y-%m-%d %H:%M:%S') == self.buy_time: # 判断是否到抢购时间
                for i in range(1, 21):  # 每隔0.2秒抢购一次,尝试抢购20次
                    print(now.strftime('%Y-%m-%d %H:%M:%S'))
                    print("第%d次抢购" % i)
                    self.webdriver.find_element(By.CSS_SELECTOR, '.jdcheckbox').click()  # 此处点击的是在购物车页面选中商品的按钮
                    self.webdriver.find_element_by_link_text("去结算").click()
                    if (self.webdriver.title == title):  # 如果检测到如果title发生改变,即点击成功,跳出循环
                        time.sleep(0.2)
                    else:
                        break
                element = (By.CSS_SELECTOR, '.checkout-submit')
                self.webdriver.execute_script('arguments[0].scrollIntoView();',
                                              self.webdriver.find_element(*element))  # 拉滚动轴到元素顶端显示
                self.webdriver.find_element(*element).click() # 创建订单成功,自行进行付款
                print('purchase success')
                quit()
            time.sleep(0.5)

if __name__ == '__main__':
    demo = jd_buy_plus("2020-03-01 12:34:00") # 填入开始抢购时间
    demo.driver()
    demo.cookie()
    demo.buy_on_time()

cookie_file.txt

  • 此文件创建即可,不需要手动进行操作

get_cookie.py

from selenium import webdriver
from selenium.webdriver.common.by import By
import time
import json

driver = webdriver.Firefox()
driver.get("https://cart.jd.com/cart.action")  # 此为购物车网站
driver.find_element(By.CSS_SELECTOR,'.login-btn').click() # 一般需要登录,此处点击的是去登录按钮
url = driver.current_url
while True: # 请在此期间进行扫码登录
    if url == driver.current_url: # 检测页面跳转
        time.sleep(0.5)
        continue
    else:
        break
cookie = driver.get_cookies()
cookie = json.dumps(cookie)

file = open(r'./cookie_file.txt','w')
file.write(cookie)
driver.quit()

原文地址:https://www.cnblogs.com/yingyingdeyueer/p/12389279.html

时间: 2024-11-10 15:26:52

京东抢购脚本升级版的相关文章

使用python实现京东抢购脚本

环境:python3.7 浏览器:火狐 在python scripts文件夹下边放入相应版本的geckodriver cmd页面: pip install selenium pip install datetime 事先需要把商品放入购物车,电脑时间和北京时间一致 from selenium import webdriver import time import datetime webdriver = webdriver.Firefox() webdriver.maximize_window(

mysql全备脚本升级版,支持多台主机,多个数据库

此脚是对上午写的脚本的升级,(前一版地址http://www.sql8.net/a/course/shujuku/Mysql/2014/0815/30340.html) 针对同事多个数据库且数据帐号,密码,主机均可能不相同的情况改写 改写后,需要两个脚本协同完成. 一为批量执行脚本 batch.sh 二为数据备份脚本databak.sh *******************************批量执行脚本 batch.sh**********************************

利用Python抢购脚本,低价货源!

因为一开始只是想爬取电脑办公类目下的商品,所以没有定义函数.(好吧 我承认自己没有一个好的python编写习惯) 最后才写的for,看起来怪怪的. 一次差不多2900个商品链接. Python代码: import requests import json import re import csv dnbg = 'https://ai.jd.com/index_new?app=Seckill&action=pcSeckillCategoryGoods&callback=pcSeckillCa

Python京东口罩实时监控抢购脚本

代码 https://github.com/hkmayfly/JDG 明天添加使用教程 参考文章: https://github.com/Rlacat/jd-automask https://github.com/cycz/jdBuyMask https://blog.csdn.net/qq_36853469/article/details/100580753 原文地址:https://www.cnblogs.com/Mayfly-nymph/p/12329471.html

静态资源发布脚本升级版

新项目新发布静态资源脚本 #!/bin/bash ########h5_mall发布脚本### #此脚本不需要加任何参数,直接运行发布h5_mall静态资源 # ############################### nginx_static_ip=10.18.2.190 tmp_time=`date +%Y-%m-%d-%H-%M-%S` remote_ip=10.18.3.200 ####过滤出最新的h5_mall静态资源####### war=`ssh ${remote_ip} "

Python爬虫,京东自动登录,在线抢购商品

京东抢购Python爬虫,自动登录京东网站,查询商品库存,价格,显示购物车详情等.可以指定抢购商品,自动购买下单,然后手动去京东付款就行. chang log2017-03-30 实现二维码扫码登陆 2017-06-27 Golang版JD_AutoBuy 运行环境Python 2.7 第三方库Requests: 简单好用,功能强大的Http请求库 beautifulsoup4: HTML文档格式化及便签选择器 环境配置 1 pip install requests 2 pip install

linux web目录文件全备脚本

#!/bin/bash#文件全备脚本#删除7天以前的文件#调用方法#yxy #www.sql8.net#[email protected]#2014-08-20#请主意所有路径都为全整目录#sh filebak.sh  要备份的目标目录 备份文件存放路径 保留文件的天数  #sh filebak.sh  /home/wd/wd/wd /home/wd/wd/bakup 7#sh filebak.sh  /home/dd/dd/dd /home/dd/dd/bakup 7 #pathpath=$1

SSLStrip 终极版 —— location 瞒天过海

之前介绍了 HTTPS 前端劫持 的方案,尽管非常有趣.然而现实却并不理想. 其唯一.也是最大的缺陷.就是无法阻止脚本跳转.若是没有这个缺陷,那就非常完美了 -- 当然也就没有必要写这篇文章了. 说究竟,还是由于无法重写 location 这个对象 -- 它是脚本跳转的唯一渠道.虽然也流传一些 Hack 能勉强实现,但终究是不靠谱的. 其实,在近期封稿的 HTML5 标准里,已很明白了 location 的地位 -- Unforgeable. 这是个不幸的消息.只是也是件好事,让我们彻底打消各种

抢口罩神器,从此再也不用在朋友圈买高价口罩了

最近口罩产量慢慢升上去了,京东淘宝上面很多店铺都有口罩预约和抢购,但是我发现身边能抢到的人少之又少,我之前也一样,抢了几次抢不到后面放弃了,直到最近有人分享了这个抢购软件,简直就是抢口罩神器,怪不得之前一直手工抢不到,也怀疑很多人是用软件抢的,可惜那时候不知道哪里搞到这些软件.自从有了这个软件,一周抢到几次,一次 10 个,而且是市面上少有的医用外科口罩,防护能力比较强了.目前囤了几十个了,感觉差不多了,就分享下软件给大家,让大家都能抢到口罩. 1.免费获取口罩下载地址 一是公众号后台直接回复[