#这个牛逼的很
import requests
from datetime import datetime, timedelta
import time
import hmac
import hashlib
import base64
import urllib.parse
import json
def send_dingtalk_message(webhook, secret, message):
timestamp = str(round(time.time() * 1000))
secret_enc = secret.encode('utf-8')
string_to_sign = '{}\n{}'.format(timestamp, secret)
string_to_sign_enc = string_to_sign.encode('utf-8')
hmac_code = hmac.new(secret_enc, string_to_sign_enc, digestmod=hashlib.sha256).digest()
sign = urllib.parse.quote_plus(base64.b64encode(hmac_code))
webhook = '{}×tamp={}&sign={}'.format(webhook, timestamp, sign)
headers = {'Content-Type': 'application/json'}
data = {"msgtype": "text", "text": {"content": message}}
response = requests.post(url=webhook, headers=headers, data=json.dumps(data))
print(response.text)
def get_klines(symbol, interval, limit=500):
url = "https://fapi.binance.com/fapi/v1/klines"
params = {'symbol': symbol, 'interval': interval, 'limit': limit}
response = requests.get(url, params=params)
return response.json()
def calculate_ema(prices, days, smoothing=2):
ema = [sum(prices[:days]) / days]
for price in prices[days:]:
ema.append((price * (smoothing / (1 + days))) + ema[-1] * (1 - (smoothing / (1 + days))))
return ema
def calculate_macd(symbol, interval):
klines = get_klines(symbol, interval)
close_prices = [float(kline[4]) for kline in klines]
original_dates = [datetime.utcfromtimestamp(int(kline[0]) / 1000) for kline in klines]
fast_ema = calculate_ema(close_prices, 6)
slow_ema = calculate_ema(close_prices, 7)
dates = original_dates[-len(slow_ema):] # 调整dates以匹配slow_ema的长度
macd_line = [f - s for f, s in zip(fast_ema[-len(slow_ema):], slow_ema)]
signal_line = calculate_ema(macd_line, 4)
dates = dates[-len(signal_line):] # 再次调整dates以匹配signal_line的长度
macd_line = macd_line[-len(signal_line):] # 确保长度匹配
crosses = []
for i in range(1, len(signal_line)):
if macd_line[i] > signal_line[i] and macd_line[i - 1] < signal_line[i - 1] and macd_line[i] < 0:
crosses.append((dates[i] + timedelta(hours=8), '水下金叉预测上涨', macd_line[i]))
elif macd_line[i] < signal_line[i] and macd_line[i - 1] > signal_line[i - 1] and macd_line[i] > 0:
crosses.append((dates[i] + timedelta(hours=8), '水上死叉预测下跌', macd_line[i]))
return crosses
def main():
symbol = 'BTCUSDT'
interval = '3m'
sent_crosses = set() # 使用集合来存储已发送的交叉点的时间戳
while True:
try:
crosses = calculate_macd(symbol, interval)
for cross in crosses[-1:]:
last_cross_date, cross_type, dif_value = cross
# 转换为简单的字符串格式以进行比较和存储
cross_signature = f"{last_cross_date.strftime('%Y-%m-%d %H:%M:%S')}_{cross_type}"
if cross_signature not in sent_crosses:
sent_crosses.add(cross_signature) # 添加到已发送集合
message = f"{last_cross_date.strftime('%Y-%m-%d %H:%M:%S')} {cross_type} DIF数值: {dif_value:.4f} 穿越"
print(message)
# 发送钉钉消息
send_dingtalk_message(webhook_url, secret, message)
else:
print("已发送过的交叉点,跳过。")
except Exception as e:
print(f"Error: {e}")
time.sleep(2) # 等待2秒再次检查
if __name__ == "__main__":
webhook_url = "https://oapi.dingtalk.com/robot/send?access_token=8a6ddcf98d3b47c63333580bfe9d0bad55b17272eea05cc9c0af7f7be4de070d"
secret = "你的秘钥"
main()
3m水下和水上的金叉和死叉这个牛逼的很
最后编辑于 :
©著作权归作者所有,转载或内容合作请联系作者
- 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
- 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
- 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...