這篇文章主要為大家詳細介紹了python實現圖書館研習室自動預約功能,具有一定的參考價值,有興趣的小伙伴們可以參考一下
本文為大家分享了python實現圖書館研習室自動預約的具體代碼,供大家參考,具體內容如下
簡介
#現在好多學校為學生提供了非常良好的學習環境,通常體現在自習教室的設施設備。對此不得不提一句的就是我們學校的圖書館,隨著新圖書館的修建,館內也設置了多個功能區,每層分為A、B、C、D四個區域,由南北連廊相連,中間由旋轉樓梯貫通一至五層。 A區為自修區;B區及C區為藏閱一體的社會科學與自然科學書庫;D區為專項功能區,包含影視廳、數位媒體創客體驗中心、智慧訓練教室、雲端桌面電子閱覽室等;B、C區東西連廊設有大小十二間研習室;南北連廊設有休閒閱讀區。
上面那段我是從圖書館官網上抄的,不過真的得為學校的圖書館點個讚。回歸本篇文章正題,學校免費為廣大師生提供了舒適優良設備齊全的研習室。但這些研習室是需要進行線上預約才能夠進入使用,每天的00:00開啟下一天的預約,因此要想約到一個時段(3小時)的研習室,可謂得「挑燈夜戰」。當然,在這個過程中手速快將有巨大的優勢。如果晚上休息的早,手速又不快,基本上就別想預約到研習室了。剛好最近學了一點python爬蟲,就打算用爬蟲幫我完成這個艱鉅的任務了。哈哈哈哈! (ps:防止惡意訪問,所有連結就不放了哈)
python實現思路
##想想思路還是挺簡單的,無非就是登入帳號、查找房間、提交預約。那就讓我們試試看:登入帳號先開啟我們研習室預約的登入介面,連結為:U2FsdGVkX19NdfJkghN54Msvy1zl7AucRur/ct0nz4orPI7uLkSDs#vuFMgr0fGcO ##rn這裡就需要同一個cookie在上面的幾個圖中,我們都能看到有個cookie值。要確保同步,這裡就需要做到,我們取得驗證碼時的cookie值和提交帳號密碼時的cookie值一致。因此,在我的程式中,我先做的一個步驟時先取得一個cookie值,然後將這個cookie值作為headers中的一個參數。登入的想法就是這樣了,補充一句,這裡的驗證碼我是自己手動辨識的>﹏<。
找房間#這個步驟其實是一個無用的步驟,為什麼有這個步驟,按照人為預約習慣,我們會產生怎麼一個步驟,但是如果使用爬蟲,只要成功登入之後就可以直接提交預約的表單。當然,如果要使得自動預約程序更加智能,便可以添加這個步驟,可以查看那些房間是還可以預約的,在這裡自訂的補充一些規則。我就略過了。 。 。
提交預約
同登入一樣,我們也手動的提交一次,去查看網路情況,便可以用python模擬這一過程。這裡我就不在貼圖解釋,這裡提交也是用requests.post的方法。不過一點要注意的是,這裡的headers和登入時的headers是不一樣的,所以在此提醒各位,如果在其他類似的預約程序中可以注意看看不同內容post時的headers是否一致。我在這裡就被坑了一會兒。
#!/usr/bin/env python # _*_ coding:utf-8 _*_ # # @Version : 1.0 # @Time : 2018/4/10 # @Author : 圈圈烃 # @File : reservation_4.py import requests import re import json import datetime import time def get_cookies(): """获得cookies""" url = 'http://**************' s = requests.session() s.get(url) ck_dict = requests.utils.dict_from_cookiejar(s.cookies) # 将jar格式转化为dict ck = 'JSESSIONID=' + ck_dict['JSESSIONID'] # 重组cookies """获得二维码""" path = './code.png' get_cookies_headers = { 'user-anget': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64; rv:59.0) Gecko/20100101 Firefox/59.0', 'Cookie': ck} get_cookies_url = 'http://**************' code_image = requests.get(get_cookies_url, headers=get_cookies_headers) with open(path, 'wb') as fn: fn.write(code_image.content) fn.close() print('验证码保存成功') return ck def login(cookies, hour, minute): login_headers = { 'Accept': 'text/html,application/xhtml+xml,application/xml;q=0.9,*/*;q=0.8', 'Accept-Encoding': 'gzip, deflate', 'Accept-Language': 'zh-CN,zh;q=0.8,zh-TW;q=0.7,zh-HK;q=0.5,en-US;q=0.3,en;q=0.2', 'Cache-Control': 'no-cache', 'Connection': 'keep-alive', 'Content-Length': '45', 'Content-Type': 'application/x-www-form-urlencoded', 'Cookie': cookies, 'Host': '**************', 'Pragma': 'no-cache', 'Referer': 'http://**************', 'Upgrade-Insecure-Requests': '1', 'User-Agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64; rv:59.0) Gecko/20100101 Firefox/59.0' } login_url = 'http://**************' login_data = { 'codeImage': input('请输入验证码:'), 'uname': '**************', 'upass': '**************' } requests.post(login_url, data=login_data, headers=login_headers) res = requests.get('http://**************', headers=login_headers) reg_h = r'<option value=(.*?)>\d{4}-\d{2}-\d{2}' # 匹配可提供预约的hash value_h = re.findall(reg_h, res.text) """定时""" counter = 0 while (True): now = datetime.datetime.now() # 获取当前系统时间 if now.hour == hour and now.minute == minute: break time.sleep(0.5) # print(now) counter = counter + 1 if counter == 240: res = requests.get('http://**************', headers=login_headers) reg_h = r'<option value=(.*?)>\d{4}-\d{2}-\d{2}' # 匹配可提供预约的hash reg_t = r'(\d{4}-\d{2}-\d{2})' # 匹配可提供预约的日期 value_h = re.findall(reg_h, res.text) value_t = re.findall(reg_t, res.text) with open('./con_log.txt', 'a') as fjs: fjs.write(eval(value_h[-1])+' '+value_t[-1]+' '+str(now)+' \n') fjs.close() print('保存成功') counter = 0 return str(eval(value_h[-1])) def reservation(day_hash, cookies, stime, etime): reservation_data = { '_etime': etime, # 结束时间11点,其值为11*60=660 '_roomid': '1285b3ca77594b3095c7b89d4922553c', # 房间Id '_seatno': '', '_stime': stime, # 开始时间8点,其值为8*60=480 '_subject': '学习', # 研讨主题 '_summary': '学习', # 研讨大纲 'ruleId': day_hash, 'usercount': 3, # 预约人数 'users': '**************', # 学号 'UUID': '**************' } reservation_headers = { 'Accept': 'application/json, text/javascript, */*; q=0.01', 'Accept-Encoding': 'gzip, deflate', 'Accept-Language': 'zh-CN,zh;q=0.8,zh-TW;q=0.7,zh-HK;q=0.5,en-US;q=0.3,en;q=0.2', 'Cache-Control': 'no-cache', 'Connection': 'keep-alive', 'Content-Length': '239', 'Content-Type': 'application/json', 'Cookie': cookies, 'Host': '**************', 'Pragma': 'no-cache', 'Referer': 'http://**************', 'User-Agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64; rv:59.0) Gecko/20100101 Firefox/59.0' } reservation_js = json.dumps(reservation_data) reservation_url = 'http://**************' status = requests.post(reservation_url, data=reservation_js, headers=reservation_headers) # print(stime, etime) # print(status) print(status.text) def main(): """预约策略一:11:20-20.40""" full_stime = ['1060', '870', '680'] full_etime = ['1240', '1050', '860'] """预约策略二:10:00-13:00;13:50-16:50;17:40-20:40""" stime = ['1060', '830', '600'] etime = ['1240', '1010', '780'] cookies = get_cookies() day_hash = login(cookies, 0, 0) # 设定定时时间 for i in range(0, 3): reservation(day_hash, cookies, stime[i], etime[i]) if __name__ == '__main__': main()
#實現效果
自從學了python,媽媽再也不用擔心我搶不到研習室了。在程式中加幾行定時的程序之後,便可以在00:00自動幫我預約研習室了。透過測試發現,預約時很大程度上是能夠約到房間的,例如在4-12號,約好三個時間段是用了7秒,但是在4-13號居然花了21秒,而且使得一個時間段被其他同學約走了。當然這個程式還需要進一步改進,實現完勝「手速」。
補在最後
還有不足,歡迎交流。
相關推薦:
##
以上是python實現圖書館研習室自動預約功能的詳細內容。更多資訊請關注PHP中文網其他相關文章!