dlt.py 9.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302
  1. # -*-coding: utf-8 -*-
  2. import os
  3. import sys
  4. import threading
  5. sys.path.append(os.path.join(os.path.abspath(__file__).split('AutoInfo')[0] + 'AutoInfo'))
  6. from utils.utils import *
  7. class GetData(object):
  8. def __init__(self, get_num=9999999):
  9. self.get_num = get_num
  10. self.url = 'https://webapi.sporttery.cn/gateway/lottery/getHistoryPageListV1.qry?gameNo=85&provinceId=0&pageSize={}&isVerify=1&pageNo=1'.format(
  11. get_num)
  12. self.logs_handle = LogsHandle()
  13. self.email_subject = 'dlt'
  14. self.email_title = '超级大乐透最新一期开奖查询对比'
  15. self.email_text = '获取数据时间:\n{0}\n{1}\n\n\n\n'.format(datetime.now().strftime("%Y-%m-%d %H:%M:%S"),
  16. ('-' * 90))
  17. self.logs_handle = LogsHandle()
  18. self.now_day = time.strftime('%Y-%m-%d', time.localtime())
  19. db = 'dlt'
  20. collection = 'dlt_' + self.now_day
  21. self.mongo = MongoHandle(db=db, collection=collection, del_db=False, del_collection=False, auto_remove=0)
  22. def main(self):
  23. data_list = self.req()
  24. result_data = self.data_handle(data_list)
  25. return result_data
  26. def req(self):
  27. resp = httpx.get(self.url)
  28. if resp.status_code != 200:
  29. print('state code: {}'.format(resp.status_code))
  30. log_detail = '访问失败, 状态码:{},url:{}'.format(resp.status_code, self.url)
  31. self.logs_handle.logs_write('auto_get_and_check_dlt', log_detail, 'error', False)
  32. exit(0)
  33. resp_json = resp.json()
  34. value = resp_json.setdefault('value')
  35. data_list = value.setdefault('list')
  36. if not data_list:
  37. self.logs_handle.logs_write('auto_get_and_check_dlt', '返回的数据为空, 获取数据失败', 'error', False)
  38. return
  39. print('已获取数据')
  40. return data_list
  41. def data_handle(self, data_list):
  42. result_data = []
  43. for d in data_list:
  44. numbers = d.setdefault('lotteryUnsortDrawresult')
  45. try:
  46. if len(numbers.split(' ')) < 7:
  47. continue
  48. except Exception as e:
  49. print('numbers: {}, err: {}'.format(numbers, e))
  50. continue
  51. red_list = numbers.split(' ')[:5]
  52. blue_list = numbers.split(' ')[5:]
  53. red_list.sort()
  54. blue_list.sort()
  55. try:
  56. # 切开红球,蓝球数组
  57. red1 = red_list[0]
  58. red2 = red_list[1]
  59. red3 = red_list[2]
  60. red4 = red_list[3]
  61. red5 = red_list[4]
  62. blue1 = blue_list[0]
  63. blue2 = blue_list[1]
  64. except Exception as e:
  65. print('红球或蓝球数据丢失')
  66. continue
  67. result_data.append({
  68. 'serial': d.setdefault('lotteryDrawNum'),
  69. 'red1': red1 or '',
  70. 'red2': red2 or '',
  71. 'red3': red3 or '',
  72. 'red4': red4 or '',
  73. 'red5': red5 or '',
  74. 'blue1': blue1 or '',
  75. 'blue2': blue2 or '',
  76. 'drawPdfUrl': d.setdefault('drawPdfUrl'),
  77. 'date': d.setdefault('lotteryDrawTime'),
  78. 'pool': d.setdefault('poolBalanceAfterdraw')
  79. })
  80. if result_data:
  81. return result_data
  82. else:
  83. self.logs_handle.logs_write('auto_get_and_check_dlt', '返回的数据为空, 获取数据失败', 'error', False)
  84. exit(0)
  85. class CheckMyDLT(object):
  86. def __init__(self, data):
  87. self.my_dlt = [
  88. ['10', '11', '16', '17', '18', '11', '12'],
  89. ['02', '03', '11', '12', '23', '05', '06'],
  90. ['07', '09', '15', '17', '22', '09', '11'],
  91. ['05', '06', '07', '34', '35', '02', '09'],
  92. ['09', '10', '11', '21', '22', '04', '05']
  93. ]
  94. self.data = data
  95. def main(self):
  96. print('开始数据对比')
  97. prepare_send_text, prepare_send_subject = self.process_text()
  98. self.send_data(prepare_send_subject, prepare_send_text)
  99. def process_text(self):
  100. text = ''
  101. serial_text = None
  102. subject = None
  103. for data in self.data:
  104. red_list = [data['red1'], data['red2'], data['red3'], data['red4'], data['red5']]
  105. blue_list = [data['blue1'], data['blue2']]
  106. # 只查询一期时, subject显示, 如果查询多期,则subject不显示
  107. if len(data) == 1:
  108. subject = '{}'.format(data['serial'])
  109. # 组成每期数据的text
  110. serial_text = 'serial: {}\t\tlottery draw date: {}\t\tbonus pool: {} RMB\n{}\nlottery draw num: {} + {}\n'.format(
  111. data['serial'], data['date'], data['pool'], '*' * 90,
  112. red_list, blue_list)
  113. for my_num in self.my_dlt:
  114. my_red_list = my_num[:5]
  115. my_blue_list = my_num[5:]
  116. # 使用列表推导式找出两个列表中都存在的元素
  117. red_common_elements = [element for element in red_list if element in my_red_list]
  118. blue_common_elements = [element for element in blue_list if element in my_blue_list]
  119. # 计算相等元素的数量
  120. red_equal_count = len(red_common_elements)
  121. blue_equal_count = len(blue_common_elements)
  122. serial_text += 'my nums: {} + {}\t\tred hit: {}\tblue hit: {}\n'.format(my_red_list, my_blue_list,
  123. red_equal_count,
  124. blue_equal_count)
  125. text += serial_text
  126. text += '{}\n\n\n\n'.format('*' * 90)
  127. return text, subject
  128. def send_data(self, subject, text):
  129. title = '超级大乐透最新一期开奖查询对比'
  130. SendEmail(subject, title, text).send()
  131. class SaveToDB(object):
  132. def __init__(self, data):
  133. self.logs_handle = LogsHandle()
  134. self.now_day = time.strftime('%Y-%m-%d', time.localtime())
  135. db = 'dlt'
  136. collection = 'dlt_' + self.now_day
  137. self.mongo = MongoHandle(db=db, collection=collection, del_db=False, del_collection=True, auto_remove=0)
  138. self.data = data
  139. def save_data(self):
  140. print('开始保存数据')
  141. for data in self.data:
  142. data_to_insert = {
  143. "serial": data.setdefault('serial'),
  144. "red1": data.setdefault('red1'),
  145. "red2": data.setdefault('red2'),
  146. "red3": data.setdefault('red3'),
  147. "red4": data.setdefault('red4'),
  148. "red5": data.setdefault('red5'),
  149. "blue1": data.setdefault('blue1'),
  150. "blue2": data.setdefault('blue2'),
  151. "date": data.setdefault('date'),
  152. "pool": data.setdefault('pool'),
  153. "drawPdfUrl": data.setdefault('drawPdfUrl'),
  154. "create_time": int(time.time()),
  155. "create_datetime": datetime.now().strftime("%Y-%m-%d %H:%M:%S")
  156. }
  157. self.mongo.collection.insert_one(data_to_insert)
  158. print('数据已储存, 共储存数据{}条'.format(len(self.data)))
  159. class DLT(object):
  160. def start(self, n):
  161. # # 获取数据
  162. G = GetData(n)
  163. data = G.main()
  164. return data
  165. def check(self, data):
  166. # # 读取数据并发送到邮件
  167. Check = CheckMyDLT(data)
  168. Check.main()
  169. def mongo(self, data):
  170. # 存 mongodb
  171. Mongo = SaveToDB(data)
  172. Mongo.save_data()
  173. def main(self):
  174. L = LogsHandle()
  175. L.logs_write('auto_get_and_check_dlt', 'dlt任务开始', 'start', False)
  176. data = self.start(30)
  177. if data:
  178. tasks = [
  179. self.check,
  180. self.mongo
  181. ]
  182. threads = []
  183. for i in tasks:
  184. thread = threading.Thread(target=i, args=(data,))
  185. threads.append(thread)
  186. thread.start()
  187. for thread in threads:
  188. thread.join()
  189. L.logs_write('auto_get_and_check_dlt', 'dlt任务结束', 'start', False)
  190. print('done')
  191. else:
  192. L.logs_write('auto_get_and_check_dlt', '获取数据失败', 'error', False)
  193. class Luanch(object):
  194. def start(self, n):
  195. # # 获取数据
  196. G = GetData(n)
  197. data = G.main()
  198. return data
  199. def check(self, data):
  200. # # 读取数据并发送到邮件
  201. Check = CheckMyDLT(data)
  202. Check.main()
  203. def mongo(self, data):
  204. # 存 mongodb
  205. Mongo = SaveToDB(data)
  206. Mongo.save_data()
  207. def main(self):
  208. Logs = LogsHandle()
  209. Logs.logs_write('auto_get_and_check_dlt', 'dlt任务开始', 'start', False)
  210. data = self.start(30)
  211. if data:
  212. tasks = [
  213. self.check,
  214. self.mongo
  215. ]
  216. threads = []
  217. for i in tasks:
  218. thread = threading.Thread(target=i, args=(data,))
  219. threads.append(thread)
  220. thread.start()
  221. for thread in threads:
  222. thread.join()
  223. Logs.logs_write('auto_get_and_check_dlt', 'dlt任务结束', 'start', False)
  224. print('done')
  225. else:
  226. Logs.logs_write('auto_get_and_check_dlt', '获取数据失败', 'error', False)
  227. if __name__ == '__main__':
  228. Luanch().main()
  229. # ## 单独获取数据
  230. # G = GetData()
  231. # data = G.main()
  232. # re_data = data[::-1]
  233. # save_txt = ''
  234. # for item in re_data:
  235. # save_txt += f'[[{item["red1"]}, {item["red2"]}, {item["red3"]}, {item["red4"]}, {item["red5"]}], [{item["blue1"]}, {item["blue2"]}]],\n'
  236. #
  237. # with open('dlt.txt', 'w') as f:
  238. # f.write(save_txt)