• 售前

  • 售后

热门帖子
入门百科

python实现自动打卡小程序

[复制链接]
李圆子wzl 显示全部楼层 发表于 2021-10-26 12:36:22 |阅读模式 打印 上一主题 下一主题
本文实例为大家分享了python实现主动打卡小步伐的详细代码,供大家参考,详细内容如下
  1. """
  2. 湖南大学疫情防控每日自动打卡程序v1.0
  3. author: Liu
  4. time:2021/3/16
  5. """
  6. from selenium import webdriver
  7. from selenium.webdriver.chrome.options import Options
  8. from PIL import Image
  9. from bs4 import BeautifulSoup
  10. import requests
  11. from aip import AipOcr
  12. import time
  13. from datetime import datetime
  14. import re
  15. class DailyAttend(object):
  16.   def __init__(self, browser, stu_id, passwd, t, address, tmp_yesterday, tmp_today):
  17.     self.browser = browser
  18.     self.stu_id = stu_id
  19.     self.passwd = passwd
  20.     self.t = t
  21.     self.address = address
  22.     self.tmp_yesterday = tmp_yesterday
  23.     self.tmp_today = tmp_today
  24.     self.img_path = "captcha.png"
  25.   def get_captcha_img(self):
  26.     url = "https://fangkong.hnu.edu.cn/app/#/login?redirect=%2Fhome"
  27.     self.browser.get(url)
  28.     self.browser.find_element_by_class_name("vcdoe-tips").click() # 模拟点击使验证码加载出来
  29.     time.sleep(2)
  30.     webpage = self.browser.page_source
  31.     soup = BeautifulSoup(webpage, features="html.parser")
  32.     div = soup.find("div", attrs={"class": "login-content"})
  33.     src = div.find_all("img")[2].attrs["src"] # 从html中解析出图片链接
  34.     r = requests.get(src)
  35.     if r.status_code == 200:
  36.       open(self.img_path, "wb").write(r.content)
  37.     else:
  38.       print("网络不佳,无法加载验证码图片")
  39.   def recog_captcha_img(self):
  40.     img = Image.open(self.img_path)
  41.     img = img.convert('L') # P模式转换为L模式(灰度模式默认阈值127)
  42.     count = 165 # 设定阈值
  43.     table = []
  44.     for i in range(256):
  45.       if i < count:
  46.         table.append(0)
  47.       else:
  48.         table.append(1)
  49.     img = img.point(table, '1')
  50.     img.save(self.img_path) # 保存处理后的验证码
  51.     ## 调用百度ocr
  52.     # 识别码
  53.     APP_ID = "23779944"
  54.     API_KEY = "FPgsSXsuqXk3twpqVHmNNK6g"
  55.     SECRET_KEY = "nG08oGzErk8CdMvDAynAiGdzfBjHr3NO"
  56.     # 初始化对象
  57.     client = AipOcr(APP_ID, API_KEY, SECRET_KEY)
  58.     # 读取图片
  59.     def get_file_content(file_path):
  60.       with open(file_path, 'rb') as f:
  61.         return f.read()
  62.     image = get_file_content(self.img_path)
  63.     # 定义参数变量
  64.     options = {'language_type': 'ENG', } # 识别语言类型,默认为'CHN_ENG'中英文混合
  65.     # 调用通用文字识别
  66.     result = client.basicGeneral(image, options) # 高精度接口 basicAccurate
  67.     for word in result['words_result']:
  68.       self.captcha = (word['words'])
  69.   def login(self):
  70.     ## 登录
  71.     while True:
  72.       self.browser.find_element_by_css_selector("[type=text]").send_keys(self.stu_id)
  73.       self.browser.find_element_by_css_selector("[type=password]").send_keys(self.passwd)
  74.       self.browser.find_element_by_css_selector("[type=number]").send_keys(self.captcha)
  75.       self.browser.find_element_by_tag_name("button").click()
  76.       time.sleep(2)
  77.       page = self.browser.page_source
  78.       html = BeautifulSoup(page, features="html.parser")
  79.       err_message = html.find("p", attrs={"class": "el-message__content"})
  80.       if err_message.text == "登录成功":
  81.         print("登录成功!")
  82.         break
  83.       elif err_message.text == "账号或密码错误":
  84.         print("账号或密码错误!请重新输入!")
  85.         self.stu_id = input("请输入学号:")
  86.         self.passwd = input("请输入密码:")
  87.         continue
  88.       else:
  89.         self.get_captcha_img()
  90.         self.recog_captcha_img()
  91.         continue
  92.   def attend(self):
  93.     success_messages = self.browser.find_elements_by_css_selector('p[class=el-message__content]')
  94.     success_messages = [message.text for message in success_messages]
  95.     if "今日已打卡" in success_messages:
  96.       print("今日已打卡!")
  97.       time.sleep(60)
  98.     else:
  99.       ## 选择打卡定位
  100.       self.browser.find_elements_by_xpath('//div/span[text()="正在获取定位..."]')[1].click()
  101.       time.sleep(1)
  102.       for i in range(17):
  103.         self.browser.find_elements_by_xpath('//ul/li')[i + 1].click()
  104.       time.sleep(1)
  105.       self.browser.find_element_by_xpath('//ul/li[text()="岳麓区"]').click()
  106.       time.sleep(1)
  107.       self.browser.find_element_by_xpath('//div/button[text()="确认"]').click()
  108.       time.sleep(1)
  109.       ## 输入相关打卡信息并点击打卡按钮
  110.       self.browser.find_elements_by_css_selector('input[placeholder="街道门牌、楼层房间号等信息"]')[1].send_keys(self.address)
  111.       temp = self.browser.find_elements_by_css_selector("input[placeholder=请输入]")
  112.       temp[0].send_keys(self.tmp_yesterday)
  113.       temp[1].send_keys(self.tmp_today)
  114.       self.browser.find_elements_by_css_selector(
  115.         'button[class="btnDaka van-button van-button--info van-button--normal van-button--block"]')[1].click()
  116.       today = datetime.now().strftime("%Y-%m-%d")
  117.       print(today + "打卡成功!")
  118.       time.sleep(60)
  119. if __name__ == "__main__":
  120.   ## 欢迎界面
  121.   print("=" * 100)
  122.   print("打卡小程序")
  123.   print("欢迎你湖南大学的朋友!开始使用吧!")
  124.   print("=" * 100)
  125.   ## 用户输入
  126.   while True:
  127.     t = input("请输入你的每日打卡时间(24小时制, 例如:00:10):")
  128.     if re.search('^(([0-1][0-9])|(2[1-3])):[0-5][0-9]$', t) == None:
  129.       print("你输入的时间格式有误,请重新输入!")
  130.       continue
  131.     stu_id = input("请输入你的学号:")
  132.     passwd = input("请输入个人门户密码:")
  133.     address = input("请输入你的打卡详细地址(例如:湖南大学北校区1舍):")
  134.     tmp_yesterday = input("请输入你的昨日体温:")
  135.     tmp_today = input("请输入你的今日体温:")
  136.     print("=" * 100)
  137.     if input("请检查你的输入是否无误,若有误则输入y并重新输入,若无误则输入n:") == "n":
  138.       print("=" * 100)
  139.       break
  140.   user_info = {
  141.     't': t,
  142.     'stu_id': stu_id,
  143.     'passwd': passwd,
  144.     'address': address,
  145.     'tmp_yesterday': tmp_yesterday,
  146.     'tmp_today': tmp_today
  147.   }
  148.   ## 浏览器设置
  149.   chrome_options = Options()
  150.   chrome_options.add_argument("--headless")
  151.   chrome_options.add_argument("--disable-gpu")
  152.   chrome_options.add_experimental_option('excludeSwitches', ['enable-logging'])
  153.   browser = webdriver.Chrome(executable_path="chromedriver.exe", options=chrome_options)
  154.   ## 打卡
  155.   app = DailyAttend(browser, **user_info) # 实例化打卡器
  156.   print("正在等待打卡时间到来...")
  157.   while True:
  158.     if datetime.now().strftime("%H:%M") == t:
  159.       app.get_captcha_img()
  160.       app.recog_captcha_img()
  161.       app.login()
  162.       app.attend()
  163.     else:
  164.       time.sleep(10)
复制代码
以上就是本文的全部内容,希望对大家的学习有所资助,也希望大家多多支持草根技术分享。

帖子地址: 

回复

使用道具 举报

分享
推广
火星云矿 | 预约S19Pro,享500抵1000!
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

草根技术分享(草根吧)是全球知名中文IT技术交流平台,创建于2021年,包含原创博客、精品问答、职业培训、技术社区、资源下载等产品服务,提供原创、优质、完整内容的专业IT技术开发社区。
  • 官方手机版

  • 微信公众号

  • 商务合作