加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
文件
克隆/下载
main.py 19.25 KB
一键复制 编辑 原始数据 按行查看 历史
修明 提交于 2024-12-22 17:13 . 新增预填功能,仅限单文本
# -*- coding: UTF-8 -*-
'''
@File :main.py
@IDE :PyCharm
@Author :修明
@Email :lzmpt@qq.com
@Date :2024/12/22 0022 16:30
@Detail :
'''
#!/usr/bin/env python
# -*- coding: utf-8 -*-
# @Time : 2022/11/18 9:43
# @Author : 修明
# @File : Registration_tool_assistance.py
# @Description :
import base64
import json
import os
import threading
import time
from datetime import datetime
import cv2
import requests
from deta import Deta
from rich import pretty
from rich import print as print
from rich.console import Console as console
from rich.table import Table
import config
pretty.install()
requests.packages.urllib3.disable_warnings()#清除出现https安全警告
class login():
def __init__(self):
self.url = config.api_prod
self.headers = {
'accept': 'application/json, text/plain, */*',
'accept-language': 'zh-CN,zh;q=0.9',
'cache-control': 'no-cache',
'dnt': '1',
'origin': 'https://p.baominggongju.com',
'pragma': 'no-cache',
'priority': 'u=1, i',
'sec-ch-ua': '"Microsoft Edge";v="131", "Chromium";v="131", "Not_A Brand";v="24"',
'sec-ch-ua-mobile': '?0',
'sec-ch-ua-platform': '"Windows"',
'sec-fetch-dest': 'empty',
'sec-fetch-mode': 'cors',
'sec-fetch-site': 'cross-site',
'user-agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/131.0.0.0 Safari/537.36 Edg/131.0.0.0'
}
self.code = ''
self.token = ''
# 获取二维码
def get_codeimage(self):
url = config.api_prod + config.Config['api_login_code']
response = requests.request("GET", url, headers=self.headers)
response = json.loads(response.text)
self.code = response["data"]["code"]
qrcode = (response["data"]["qrcode"]).replace('data:image/jpg;base64,', '')
page_content = base64.b64decode(qrcode)
file_path = './login.jpg'
with open(file_path, 'wb') as f:
f.write(page_content)
# 识别二维码
def check(self):
url = config.api_prod + config.Config['api_pc_login']
response = requests.request("GET", url,params={"code": self.code, "source": "h5"}, headers=self.headers)
response = json.loads(response.text)
msg = response["msg"]
# print(response)
if msg != 'ok':
token = ''
else:
token = response['data']['access_token']
self.token = token
# print("token:",token)
return token
def image_show(self,):
img = cv2.imread('login.jpg')
cv2.imshow('image', img)
cv2.waitKey(0)
def check_token(self,token):
url = f'https://api-xcx-qunsou.weiyoubot.cn/xcx/enroll/v1/userinfo?access_token={token}'
response = requests.request("GET", url, headers=self.headers)
response = json.loads(response.text)
msg = response["msg"]
if msg == 'ok':
self.token = token
return True
else:
return False
def login(self):
console.rule('登录模块')
if os.path.exists('token.txt'):
with open('token.txt', 'r') as f:
token = f.read()
token_status = self.check_token(token)
if token_status: return self.token
else:
self.get_codeimage()
console.log("请使用微信扫描二维码进行登录,扫完后关闭窗口!")
thead = threading.Thread(target=self.image_show)
thead.start()
while (1):
token = self.check()
if token != '':
console.log("登陆成功!")
console.log("获取token成功!\ntoken:" + token)
with open('token.txt', 'w') as f:
f.write(token)
break
else:
with console.status(f'还未登录,请等待!', spinner='line'):
time.sleep(2)
return self.token
class Lecture(object):
def __init__(self,):
self.url = 'https://api-xcx-qunsou.weiyoubot.cn/xcx/enroll'
self.post_url = 'https://api-xcx-qunsou.weiyoubot.cn/xcx/enroll/v5/enroll'
self.headers = {
'accept': 'text/html,application/xhtml+xml,application/xml;q=0.9,image/avif,image/webp,image/apng,*/*;q=0.8,application/signed-exchange;v=b3;q=0.7',
'accept-language': 'zh-CN,zh;q=0.9',
'cache-control': 'no-cache',
'pragma': 'no-cache',
'priority': 'u=0, i',
'sec-ch-ua': '"Google Chrome";v="131", "Chromium";v="131", "Not_A Brand";v="24"',
'sec-ch-ua-mobile': '?0',
'sec-ch-ua-platform': '"Windows"',
'sec-fetch-dest': 'document',
'sec-fetch-mode': 'navigate',
'sec-fetch-site': 'none',
'sec-fetch-user': '?1',
'upgrade-insecure-requests': '1',
'user-agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/131.0.0.0 Safari/537.36'
}
self.token = ''
self.eid = ''
self.infos = {}
self.registration_eid = []
self.registration_map = {}
self.config = None
self.get_config()
def get_config(self):
with open('config.json', 'r',encoding='utf-8') as file:
# 这里的'your_file.json'需要替换为实际的文件名
data = file.read()
self.config = json.loads(data)
def time_now(self,):
# 打印当前时间
timenow = datetime.now()
return timenow
# 打印按指定格式排版的时间
# time2 = datetime.datetime.now().strftime('%Y-%m-%d %H:%M:%S')
# print(time2)
def all_registration(self,):
url = config.api_prod + config.Config["api_user_history"]
ret = requests.request("GET", url,params={"access_token": self.token}, headers=self.headers).json()
# status:1 进行中 2结束
index = 1
for i in ret['data']:
if i['status'] == 0 or i['status'] == 1:
# 已满
if i['count'] >= i['limit']:
continue
print("编号:%d 讲座:%s" % (index, i["title"]))
index += 1
self.registration_eid.append(i['eid'])
self.registration_map[i['eid']] = i["title"]
assert len( self.registration_map)!=0 , "异常,当前没有讲座信息,请使用微信小程序浏览目标讲座"
#获取开始时间
def get_time(self,):
url = config.api_prod + config.Config["api_detail"]
index = int(console.input("请选择(填编号):"))
self.eid = self.registration_eid[index-1]
# response = requests.request("GET", self.url + f'/v3/detail?eid={self.registration_eid[index-1]}&access_token={self.token}&admin=0&from=detail&referer=', headers=self.headers)
response = requests.request("GET", url,params={"access_token": self.token,"eid":self.registration_eid[index-1]}, headers=self.headers)
data = response.json()
timestep = data['data']['start_time']
timeStamp = float(timestep)
timeArray = time.localtime(timeStamp)
timegep = time.strftime("%Y-%m-%d %H:%M:%S", timeArray)
console.log('讲座开始时间:' + str(timegep))
console.rule(f'当前选择讲座名称:{self.registration_map[self.registration_eid[index - 1]]}')
return timestep,data,timegep,index
#获取相关参数
def get_optioninfo(self,index):
url = config.api_prod + config.Config["api_req_detail"]
# url = config.api_prod + config.Config["api_detail"]
response = requests.request("GET", url,params={"access_token": self.token,"eid":self.registration_eid[index-1]}, headers=self.headers)
print(url + f"?access_token={self.token}&eid={self.registration_eid[index-1]}")
data = response.json()
info = data["data"]["req_info"]
index = 0
namelist = []
typelist = []
optionslist = []
options = []
keys = []
notes = []
for i in info:
namelist.append(i["field_name"])
typelist.append(i["type_text"])
keys.append(i["field_key"])
if i["type_text"] == '多项选择':
optionslist.append(i["options"])
options.append(i["new_options"])
elif i["type_text"] == '单项选择':
option_name = []
# print(i["options"])
for option in i["options"]:
option_name.append(option['text'])
options.append(i["new_options"])
optionslist.append(option_name)
else:
optionslist.append(0)
options.append(0)
if i["field_name"] == "验证数字":
max_number = i['max_value']
min_number = i["min_value"]
notes.append(f"输入{min_number}-{max_number}之间的数字")
notes.append("无")
#输出所需讲座信息全部内容
table = Table(show_header=True, header_style="bold magenta")
table.title = "讲座需要填写的信息"
table.add_column("信息标题", style="dim", width=12, justify="center")
table.add_column("信息类型", justify="center")
table.add_column("选项信息", justify="center")
table.add_column("备注信息", justify="center")
for i in range(len(namelist)):
name = str(namelist[i])
type = str(typelist[i])
if optionslist[i] == 0:
option = "需要手动填写信息"
else:
option = str(optionslist[i])
table.add_row(
name,
type,
option,
notes[i]
)
table.add_row("","","")
console.print(table)
console.rule("讲座信息参数填写")
infoes = []
for i in range(len(namelist)):
for key, value in self.config.items():
if key in namelist[i]:
date = {"field_name": namelist[i], "field_value": value, "field_key": keys[i], "ignore": 0}
infoes.append(date)
console.print(f'输入成功! 参数{i + 1}设置成功')
console.rule()
if len(infoes) != (i+1):
if '+' in namelist[i] or '-' in namelist[i] or '*' in namelist[i] or '/' in namelist[i]:
console.print(f'参数{i + 1}:' + namelist[i])
console.print(f'参数{namelist[i]}类别:' + typelist[i])
expression = namelist[i].replace('=', '')
result = eval(expression)
date = {"field_name": namelist[i], "field_value": result, "field_key": keys[i], "ignore": 0}
infoes.append(date)
console.print(f'输入成功! 参数{i + 1}设置成功')
console.rule()
# elif typelist[i] != '单项选择' and typelist[i] != '多项选择':
# console.print(f'参数{i+1}:' + namelist[i])
# console.print(f'参数{namelist[i]}类别:' + typelist[i])
# name = console.input(f'请输入参数 {namelist[i]} 的内容:')
# date = {"field_name": namelist[i], "field_value": name, "field_key": keys[i], "ignore": 0}
# infoes.append(date)
# console.print(f'输入成功! 参数{i+1}设置成功')
# console.rule()
# elif typelist[i] == '单项选择':
# console.print(f'参数{i + 1}:' + namelist[i])
# console.print(f'参数 {namelist[i]} 类别:' + typelist[i])
# console.print('选项内容:')
# index = 1
# for option in optionslist[i]:
# console.print(f' {index}:{option}')
# index += 1
# xuanze = int(console.input(f'请输入参数 {namelist[i]} 的选项(注意是{typelist[i]}哦):'))
# value = options[i][xuanze-1]['key']
# date = {"field_name": namelist[i],
# "field_value": optionslist[i][xuanze-1],
# "field_key": keys[i],
# "new_field_value": value,
# "ignore": 0}
# infoes.append(date)
# # print(date)
# console.print(f'输入成功! 参数{i + 1}设置成功')
# console.rule()
# elif typelist[i] == '多项选择':
# console.print(f'参数{i + 1}:' + namelist[i])
# console.print(f'参数 {namelist[i]} 类别:' + typelist[i])
# console.print('选项内容:')
# index = 1
# for option in optionslist[i]:
# console.print(f' {index}:{option}')
# index += 1
# value = []
# field_value = []
# while True:
# xuanze = int(console.input(f'请输入参数{namelist[i]}的选项(注意是{typelist[i]}哦,依次输入,输入0进行退出):'))
# if xuanze == 0:
# break
# else:
# value.append(options[i][xuanze - 1]['key'])
# field_value.append(optionslist[i][xuanze-1])
# date = {"field_name": namelist[i],
# "field_value": field_value,
# "field_key": keys[i],
# "new_field_value": value,
# "ignore": 0}
# infoes.append(date)
# # print(date)
# console.print(f'输入成功! 参数{i + 1}设置成功')
# console.rule()
# else:
# console.print('该程序目前仅仅支持文本,选择,其他待开发,如有需求请联系作者,lzmpt@qq.com')
console.print('请仔细检查自己所填写字段')
console.print(infoes)
return infoes
def post(self,payload):
try:
console.print()
response = requests.request("POST", self.post_url, headers=self.headers, data=payload, verify=False, timeout=1)
t = response.text
jsonData = json.loads(t)
console.print(jsonData)
if jsonData['msg'] == '报名人数已满或项目数量不足' or jsonData['msg'] == '提交次数超过限制' or jsonData['msg'] == 'invalid parameter' or jsonData['msg'] == '' or jsonData['msg'] == '活动期间,只允许提交1次':
console.print()
console.print(jsonData['msg'])
return 0,jsonData['msg']
else:
return 1,jsonData['msg']
except Exception as e:
console.print("请求受阻,重新发起请求")
def personal(self,):
url = 'https://gitee.com/ygxiu/lecture-registration/raw/master/README.assets/Snipaste_2022-11-20_11-08-44.png'
os.system('"C:\Program Files\internet explorer\iexplore.exe" https://gitee.com/ygxiu/lecture-registration/raw/master/README.assets/Snipaste_2022-11-20_11-08-44.png')
def run(self,):
timenow = self.time_now()
console.rule("微信历史讲座信息")
self.all_registration()
start_time, data, timegep,index = self.get_time()
info = self.get_optioninfo(index)
data = {"eid": "", "info": info, "on_behalf": 0, "items": [], "access_token": ""}
data["eid"] = self.eid
data["access_token"] = self.token
payload = json.dumps(data)
console.rule("预约报名模块")
console.print(f'讲座开始时间:{timegep}')
while True:
timenow = self.time_now()
time_loss = start_time - int(time.time())
with console.status(f'距离开始时间还有{time_loss}秒',spinner= 'dots'):
print(time_loss)
if time_loss <= -self.config["延迟时间(单位秒)"]:
t, message = self.post(payload)
if t == 0:
if message == '' or message == '提交次数超过限制':
console.log("报名成功!")
console.log("如果对您有帮助的话,可以帮忙点个star吗?")
self.personal()
elif message == '报名人数已满或项目数量不足' or message == 'invalid parameter':
console.log('很尴尬,未抢到或者程序出错,请检查自己的微信!')
break
else:
console.log("还未报名,刷新中...")
time.sleep(1)
time.sleep(1)
def version_request(versionold):
url = "https://gitee.com/ygxiu/lecture-registration/raw/master/version"
url2 = 'https://gitee.com/ygxiu/lecture-registration/raw/master/tittler'
payload = {}
headers = {
'Accept' : 'text/html,application/xhtml+xml,application/xml;q=0.9,image/avif,image/webp,image/apng,*/*;q=0.8,application/signed-exchange;v=b3;q=0.9',
'Accept-Language' : 'zh-CN,zh;q=0.9,zh-TW;q=0.8,en-US;q=0.7,en;q=0.6',
'Referer' : 'https://gitee.com/ygxiu/lecture-registration/edit/master/version',
'Sec-Fetch-Dest' : 'document',
}
response = requests.request("GET", url, headers = headers, data = payload)
responses = requests.request("GET", url2, headers = headers, data = payload).text
version = response.text[8:]
console.rule(f"版本:{versionold}")
if version != versionold:
console.print(f"当前版本:{versionold} 最新版本:{version}")
messageversion = '当前有更新版本,请尽快前往更新界面进行更新!'
return 1
else:
console.print(f"当前版本:{versionold} 最新版本:{version}")
messageversion = '当前为最新版本!'
return 0
if __name__ == '__main__':
version = '2.0.0'
console = console(color_system='256', style=None)
console.rule("报名工具多参数测试版本")
tittle = '''
author:修明
object:微信小程序 报名工具
function:
1.扫码登陆
2.自主选择讲座
3.输出所需要填写信息及条件
4.支持填空参数以及选择参数,其他参数后续开发
GitHub:https://github.com/ygxiuming/Lecture-registration
Gitee:https://gitee.com/ygxiu/lecture-registration
'''
console.print(tittle)
t = version_request(version)
if t == 0 :
infos = {}
token = login().login()
# token = '79be2cb2d8b44ed98f8484ba990f94b1'
lecture = Lecture()
lecture.token = token
lecture.infos = infos
lecture.run()
time.sleep(600)
else:
console.print("请尽快更新最新版本!")
time.sleep(600)
Loading...
马建仓 AI 助手
尝试更多
代码解读
代码找茬
代码优化