message_dlt.py 5.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173
  1. # -*- coding: utf-8 -*-
  2. """
  3. 获取超级大乐透结果, 并匹配自己购买的号码, 配合定时执行使用
  4. """
  5. import sys
  6. import os
  7. import asyncio
  8. import httpx
  9. sys.path.append(os.path.join(os.path.abspath(__file__).split('auto')[0] + 'auto'))
  10. from utils.utils_send_gotify import GotifyNotifier
  11. from utils.utils_send_email import SendEmail
  12. class CheckDlt:
  13. def __init__(self):
  14. self.url = 'https://webapi.sporttery.cn/gateway/lottery/getHistoryPageListV1.qry?gameNo=85&provinceId=0&pageSize=1&isVerify=1&pageNo=1'
  15. self.headers = {
  16. "User-Agent": "Mozilla/5.0 (Windows NT 10.0; Win64; x64)",
  17. "Accept": "text/html,application/xhtml+xml,application/xml;q=0.9,*/*;q=0.8",
  18. "Accept-Language": "en-US,en;q=0.5",
  19. "Accept-Encoding": "gzip, deflate, br",
  20. "Connection": "keep-alive",
  21. "Content-Type": "application/json"
  22. }
  23. self.my_dlt = [
  24. ['10', '11', '16', '17', '18', '11', '12'],
  25. ['02', '03', '11', '12', '23', '05', '06'],
  26. ['07', '09', '15', '17', '22', '09', '11'],
  27. ['05', '06', '07', '34', '35', '02', '09'],
  28. ['09', '10', '11', '21', '22', '04', '05']
  29. ]
  30. async def req(self):
  31. async with httpx.AsyncClient() as client:
  32. try:
  33. resp = await client.get(self.url, timeout=5)
  34. if resp.status_code != 200:
  35. print('state code: {}'.format(resp.status_code))
  36. log_detail = '访问失败, 状态码:{},url:{}'.format(resp.status_code, self.url)
  37. print(log_detail)
  38. return None
  39. except Exception as e:
  40. print(f'请求失败 {e}')
  41. return None
  42. return resp.json()
  43. def data_handle(self, data):
  44. if not data:
  45. print('获取数据为空')
  46. return None
  47. value = data.get('value')
  48. data_list = value.get('list')
  49. if not data_list:
  50. print('获取数据为空')
  51. return None
  52. result_data = []
  53. for d in data_list:
  54. numbers = d.get('lotteryUnsortDrawresult')
  55. try:
  56. if len(numbers.split(' ')) < 7:
  57. continue
  58. except Exception as e:
  59. print('numbers: {}, err: {}'.format(numbers, e))
  60. continue
  61. red_list = numbers.split(' ')[:5]
  62. blue_list = numbers.split(' ')[5:]
  63. red_list.sort()
  64. blue_list.sort()
  65. try:
  66. # 切开红球,蓝球数组
  67. red1 = red_list[0]
  68. red2 = red_list[1]
  69. red3 = red_list[2]
  70. red4 = red_list[3]
  71. red5 = red_list[4]
  72. blue1 = blue_list[0]
  73. blue2 = blue_list[1]
  74. except Exception as e:
  75. print('红球或蓝球数据丢失')
  76. continue
  77. result_data.append({
  78. 'serial': d.get('lotteryDrawNum'),
  79. 'red1': red1 or '',
  80. 'red2': red2 or '',
  81. 'red3': red3 or '',
  82. 'red4': red4 or '',
  83. 'red5': red5 or '',
  84. 'blue1': blue1 or '',
  85. 'blue2': blue2 or '',
  86. 'drawPdfUrl': d.get('drawPdfUrl'),
  87. 'date': d.get('lotteryDrawTime'),
  88. 'pool': d.get('poolBalanceAfterdraw')
  89. })
  90. if result_data:
  91. return result_data
  92. else:
  93. print('返回的数据为空, 获取数据失败')
  94. return None
  95. def data_compare(self, all_data):
  96. if not all_data:
  97. return '', ''
  98. data = all_data[0]
  99. red_list = [data['red1'], data['red2'], data['red3'], data['red4'], data['red5']]
  100. blue_list = [data['blue1'], data['blue2']]
  101. # 期号
  102. subject = '{}'.format(data['serial'])
  103. # 组成每期数据的text
  104. serial_text = 'serial: {}\t\tlottery draw date: {}\nbonus pool: {} RMB\n{}\nlottery draw num: {} + {}\n\n'.format(
  105. data['serial'], data['date'], data['pool'], '*' * 90,
  106. red_list, blue_list)
  107. for my_num in self.my_dlt:
  108. my_red_list = my_num[:5]
  109. my_blue_list = my_num[5:]
  110. # 使用列表推导式找出两个列表中都存在的元素
  111. red_common_elements = [element for element in red_list if element in my_red_list]
  112. blue_common_elements = [element for element in blue_list if element in my_blue_list]
  113. # 计算相等元素的数量
  114. red_equal_count = len(red_common_elements)
  115. blue_equal_count = len(blue_common_elements)
  116. serial_text += 'my nums: {} + {}\nred hit: {}\nblue hit: {}\n\n'.format(my_red_list, my_blue_list,
  117. red_equal_count,
  118. blue_equal_count)
  119. serial_text += '{}\n\n\n\n'.format('*' * 90)
  120. return serial_text, subject
  121. def send_message(self, text, subject):
  122. if not text:
  123. return
  124. title = f'dlt {subject}'
  125. # 推送到 message
  126. GotifyNotifier(title, text, 'dlt').send_message()
  127. # 发送到邮件
  128. # SendEmail(title, title, text).send()
  129. async def main(self):
  130. data = await self.req()
  131. result_data = self.data_handle(data)
  132. if not result_data:
  133. return
  134. text, subject = self.data_compare(result_data)
  135. self.send_message(text, subject)
  136. if __name__ == '__main__':
  137. asyncio.run(CheckDlt().main())