message_coin_detail.py 4.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147
  1. # -*- coding: utf-8 -*-
  2. '''
  3. 使用 httpx 获取 coinmarketcap 最新数字币数据
  4. '''
  5. import time
  6. import os
  7. import sys
  8. import httpx
  9. import re
  10. from playwright.sync_api import sync_playwright
  11. sys.path.append(os.path.join(os.path.abspath(__file__).split('auto')[0] + 'auto'))
  12. from utils.utils_send_gotify import *
  13. def get_chainalert():
  14. coin_follow_list = ['BTC', 'ETH', 'SOL', 'GRASS', 'SUI', 'DOGE', 'ARB', 'ATH', 'MOVE']
  15. # coin_follow_list = ['DOGE']
  16. text = ''
  17. data = {}
  18. with sync_playwright() as playwright:
  19. browser = playwright.chromium.launch(headless=True)
  20. context = browser.new_context()
  21. page = context.new_page()
  22. page.goto("https://chainalert.me/data/marketprice")
  23. for coin in coin_follow_list:
  24. page.fill("#marketprice_search_input", coin)
  25. page.click("#marketprice_search_btn")
  26. page.wait_for_timeout(1500)
  27. elements = page.query_selector_all("#listdata_header > li:nth-child(2) > div")
  28. text_content = [element.text_content() for element in elements]
  29. temp_data = [s.replace('↑', '').replace('↓', '').split() for s in text_content]
  30. print(temp_data[0])
  31. # 去重
  32. if temp_data[0][1] not in data:
  33. data[temp_data[0][1]] = temp_data[0]
  34. # 将去重后的数据拼接到 text 中
  35. for coin, value in data.items():
  36. text += f'Name: {coin}\n'
  37. text += f'Ranking: {value[0]}\n'
  38. text += f'Price: {value[2]}\n'
  39. text += f'24H Transaction Volume: {value[3]}\n'
  40. text += f'24H Price Change: {value[4]}\n'
  41. text += f'Market Capitalization: {value[5]}\n'
  42. text += f'Diluted Market Value: {value[6]}\n'
  43. text += '\n\n'
  44. time.sleep(1)
  45. page.goto("https://chainalert.me/data/")
  46. page.wait_for_timeout(1500)
  47. elements = page.query_selector_all(
  48. '#greedy-galay-div > div.greedy_index-svg-value-div > div.greedy-svg-value > strong')
  49. text_content = [element.text_content() for element in elements]
  50. print(f'VIX: {text_content[0] if text_content else "No Data"}')
  51. if text_content:
  52. text += f'VIX: {text_content[0]}'
  53. else:
  54. text += 'VIX: No Data'
  55. context.close()
  56. browser.close()
  57. return text
  58. def get_gas_value():
  59. url = "https://a5.maiziqianbao.net/api/v1/chains/EVM/1/gas_price"
  60. headers = {
  61. "Host": "a5.maiziqianbao.net",
  62. "Connection": "keep-alive",
  63. "x-req-token": "MDbO4FsaSUPdjCdvTUs2zY4V3rnvvYatvYyjz7SfY+aCJ8r+RFm06X2dGR8eEDK7Gc5g1TLEQySEhGerRXbDT/NS+e5QAWRU68yD8m4y/aKK+TBkIv90VwvxmvYId2BVoDPDHQCGG4o3EqRWkS93eV0twYQ7w7qvNUj2e3tpDcUZYuplPyLozgYVTegFPnDk",
  64. "Accept": "*/*",
  65. "x-app-type": "iOS-5",
  66. "x-app-ver": "1.0.1",
  67. "x-app-udid": "419815AD-3015-4B5A-92CA-3BCBED24ACEC",
  68. "x-app-locale": "en",
  69. "Accept-Language": "zh-Hans-CN;q=1.0, en-CN;q=0.9",
  70. "Accept-Encoding": "br;q=1.0, gzip;q=0.9, deflate;q=0.8",
  71. "User-Agent": "MathGas/1.0.1 (MathWallet.MathGas; build:3; macOS 13.5.0) Alamofire/5.4.4"
  72. }
  73. response = httpx.get(url, headers=headers)
  74. if response.status_code != 200:
  75. print("Error:", response.status_code)
  76. return None
  77. if not response.json():
  78. print("Not Find GAS Data. Error: No response")
  79. return None
  80. remove_last_n_chars = lambda n, n_chars=9: int(str(n)[:-n_chars]) if len(str(n)) > n_chars else n
  81. result = '\nGAS:\n'
  82. try:
  83. data = response.json()['data']
  84. fastest = remove_last_n_chars(data['fastest']['price'])
  85. fast = remove_last_n_chars(data['fast']['price'])
  86. standard = remove_last_n_chars(data['standard']['price'])
  87. low = remove_last_n_chars(data['low']['price'])
  88. base = remove_last_n_chars(data['base']['price'])
  89. result += f'fastest: {fastest}\nfast: {fast}\nstandard: {standard}\nlow: {low}\nbase: {base}'
  90. return result
  91. except Exception as e:
  92. print(e)
  93. return None
  94. def main():
  95. retry = 5
  96. text = ''
  97. for i in range(retry):
  98. try:
  99. text = get_chainalert()
  100. gas = get_gas_value()
  101. if gas:
  102. text += gas
  103. break
  104. except Exception as e:
  105. print(f'retry {i + 1}')
  106. print(e)
  107. time.sleep(5)
  108. if text:
  109. GotifyNotifier('Real-time coin price\n', text, 'AgfOJESqDKftBTQ').send_message()
  110. else:
  111. print('No Data')
  112. if __name__ == '__main__':
  113. main()