15m检查什么时候水上金叉和水下死叉


import requests
import pandas as pd
import time
from datetime import datetime, timedelta
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 = '{}&timestamp={}&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_macd(df, short_window=6, long_window=7, signal_window=4):
    df['EMA_short'] = df['Close'].ewm(span=short_window, adjust=False).mean()
    df['EMA_long'] = df['Close'].ewm(span=long_window, adjust=False).mean()
    df['MACD'] = df['EMA_short'] - df['EMA_long']
    df['Signal'] = df['MACD'].ewm(span=signal_window, adjust=False).mean()
    df['DIF'] = df['MACD'] - df['Signal']
    return df


def find_macd_crosses(df):
    crosses = []
    previous_dif = df.iloc[0]['DIF']
    for i, row in df.iterrows():
        current_dif = row['DIF']
        if previous_dif <= 0 and current_dif > 0:
            crosses.append((row['Time'], '金叉上涨', current_dif))
        elif previous_dif >= 0 and current_dif < 0:
            crosses.append((row['Time'], '死叉下跌', current_dif))
        previous_dif = current_dif
    return crosses


def convert_utc_to_local(utc_dt, offset=8):
    return utc_dt + timedelta(hours=offset)


last_cross_time = 0  # 初始化,记录上次交叉点的时间戳

def print_crosses(crosses, webhook, secret):
    global last_cross_time
    for cross in crosses:
        cross_time = cross[0] / 1000  # 获取交叉点的时间戳(秒)
        if cross_time > last_cross_time:  # 仅处理新的交叉点
            local_time = convert_utc_to_local(datetime.utcfromtimestamp(cross_time))
            time_str = local_time.strftime('%Y-%m-%d %H:%M:%S')
            message = f"穿越Time (UTC+8): {time_str}, Type: {cross[1]}, DIF: {cross[2]:.6f} 产生金叉后,等待DIF>0 在买,产生死叉后,等待DIF<0再卖。更稳妥"
            print(message)
            send_dingtalk_message(webhook, secret, message)  # 发送钉钉消息
            last_cross_time = cross_time  # 更新记录的时间戳
        else:
            print(f"No new crosses found at {datetime.now().strftime('%Y-%m-%d %H:%M:%S')} (UTC+8).")

def main():
    symbol = 'BTCUSDT'
    interval = '15m'
    webhook_url = "https://oapi.dingtalk.com/robot/send?access_token=8a6ddcf98d3b47c63333580bfe9d0bad55b17272eea05cc9c0af7f7be4de070d"
    secret = "你的秘钥"
    print("开始循环查询...")
    while True:
        klines = get_klines(symbol, interval, limit=100)
        df = pd.DataFrame(klines,
                          columns=['Time', 'Open', 'High', 'Low', 'Close', 'Volume', 'Close time', 'Quote asset volume',
                                   'Number of trades', 'Taker buy base asset volume', 'Taker buy quote asset volume',
                                   'Ignore'])
        df['Close'] = pd.to_numeric(df['Close'])

        df = calculate_macd(df)
        crosses = find_macd_crosses(df)
        if crosses:
            print_crosses(crosses, webhook_url, secret)  # 将webhook和secret传递给print_crosses函数
        else:
            print(f"No crosses found at {datetime.now().strftime('%Y-%m-%d %H:%M:%S')} (UTC+8).")

        time.sleep(2)  # 每分钟查询一次


if __name__ == "__main__":
    main()
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 216,591评论 6 501
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,448评论 3 392
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 162,823评论 0 353
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,204评论 1 292
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,228评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,190评论 1 299
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,078评论 3 418
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,923评论 0 274
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,334评论 1 310
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,550评论 2 333
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,727评论 1 348
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,428评论 5 343
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,022评论 3 326
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,672评论 0 22
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,826评论 1 269
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,734评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,619评论 2 354

推荐阅读更多精彩内容