Introdução ao Python: simples e pequenos scripts - estatísticas de transações contínuas unilaterais

Autora:bb, Criado: 2018-07-23 15:53:45, Atualizado: 2018-07-24 12:27:27

Recentemente estudei quantificação e não tenho nenhuma base, toquei algo devagar.

Hoje, um pequeno script foi usado para estudar o número de vezes que o mercado monopolista (aumento ou queda contínuo) ocorreu nos últimos 50 dias. Eu queria escrever um ↓. A identificação de turbulências e tendências é muito simples!https://www.fmz.cn/bbs-topic/1638A ideia de usar o novo baixo do último ciclo para contrastar com o novo alto deste ciclo para determinar a tendência; tendências ascendentes e descendentes podem ser usadas. Mas quando eu testei, o ciclo da linha K é definido como um período de 50 dias, o que não funciona, portanto, não há dados de suporte.

O resultado é o seguinte:

img

A ordem de saída é: id> Time> preço mais alto da fase> preço mais baixo da fase> preço de estado de queda> número de vezes de permanência

  • Filtros de um único declínio e paralelo, tais como: > declínio > declínio > declínio > declínio > declínio > declínio > declínio > declínio > declínio > declínio > declínio > declínio > declínio > declínio > declínio > declínio > declínio.
  • O preço mais alto do próximo ciclo pode ser comparado com o preço mais alto deste ciclo, ou com o preço mais alto do próximo ciclo.
  • A linha de 3 minutos é 00:57>01:00>01:57>02:00>02:57... por quê?
  • A maioria dos usuários não tem acesso ao Python, mas eles não têm acesso a ele.

Tem alguma coisa?

  • Eu acho que é muito útil, pelo menos melhor do que olhar, mas o ciclo de tempo é muito curto e não vejo a lei do olhar.
  • No entanto, se o mercado atual, de acordo com a linha do dia, tiver 12 dias consecutivos de alta unilateral, qual é a probabilidade de aumento no dia 13?
  • Eu tive essa ideia para fazer este teste, e não quero que ninguém goste, mas quero mudar de ideia e experimentar.
  • Bem-vindo ao intercâmbio, eu sou um laranja normal.

Aqui está um pouco de código simplificado.


def main():
    k_line = exchange.GetRecords(PERIOD_M1) #设置1分钟K线数据
    i1 = 0 #i1 i2分别记录涨、跌次数
    i2 = 0
    j_c = 0 #用作记录所有持续行情次数总和的变量
    for i,k_line_single in enumerate(k_line): #i为记录循环次数 从0开始 k_line_single为单行记录文本
        otherStyleTime = time.strftime("%Y--%m--%d %H:%M:%S", time.localtime(k_line_single.Time / 1000))#时间戳转换代码
        state_text = "" #重置state_text 避免状态连续继承  状态文本
        Duration = "" #重置持续行情次数变量
        if k_line_single.High > k_line[i-1].High: #判断最高价高于前一周期最高价的情况         
            i2 = 0 #重置连续下跌计数变量
            if k_line[i-1].High > k_line[i-2].High or k_line[i+1].High > k_line_single.High: #当高于前一周期或后一周期高于此周期价
                state_text = "连续上涨UP UP UP!"
                i1 += 1 #记录连续上涨次数
        elif k_line_single.High < k_line[i-1].High: #判断不为持平状态  
            i1 = 0
            if k_line[i-1].High < k_line[i-2].High or k_line[i+1].High < k_line_single.High:#当前一周期价格低于前前一周期 或 后一周期价格低于当前周期,表示一定是连续下跌
                state_text = "连续下跌LOW LOW !" 
                i2 += 1 #记录连续下跌次数
        else:
            i1 = 0 #重置连续行情次数
            i2 = 0
        if state_text == "连续上涨GO GO GO!" or state_text == "连续下跌LOW LOW !": #只有当连续上涨或下跌时 才会打印结果 
            j_c += 1
            Duration = "Duration:",i1 + i2 #连续单边行情持续次数
            Log(i+1,"-- Time:",otherStyleTime,"-- High:",k_line_single.High,"-- Low:",k_line_single.Low,"--》",state_text,Duration)
    Log("运行完毕。。符合条件的总数为:",j_c)

E então, um código sem o efeito de barra, com 21 linhas de código a mais do que o anterior.

def main():
    k_line = exchange.GetRecords(PERIOD_M1)
    state_text = "" #状态文本
    i1 = 0
    i2 = 0
    i3 =0
    state_3 = 0 #行情状态 涨=1 跌=2 平=3
    j_c = 0 #用作记录所有持续行情次数总和的变量
    for i,k_line_single in enumerate(k_line): #i为记录循环次数 从0开始 k_line_single为单行记录文本
        timeStamp = k_line_single.Time / 1000 #时间戳转换代码开始
        timeArray = time.localtime(timeStamp)
        otherStyleTime = time.strftime("%Y--%m--%d %H:%M:%S", timeArray)#时间戳转换代码结束
        
        if k_line_single.High > k_line[i-1].High: #判断最高价高于前一周期最高价的情况
            state_text = "价格出现上涨"
            i2 = 0
            i3 = 0
            state_3 = 1
            if k_line[i-1].High > k_line[i-2].High or k_line[i+1].High > k_line_single.High: #当高于前一周期或后一周期高于此周期价
                state_text = "连续上涨GO GO GO!"
                i1 += 1
        else:
            if k_line_single.High != k_line[i-1].High:
                state_text = "价格出现下跌"
                i1 = 0
                i3 = 0
                state_3 = 2
                if k_line[i-1].High < k_line[i-2].High or k_line[i+1].High < k_line_single.High:
                    state_text = "连续下跌LOW LOW !"
                    i2 += 1
            else:
                state_text = "价格相比持平"
                i1 = 0
                i2 = 0
                state_3 = 3
                if k_line[i-1].High == k_line[i-2].High:# or k_line[i+1].High == k_line_single.High:
                    state_text = "连续持平PING PING !"
                    i3 = 0 #不调试持平持续数量了
        if state_3 != 3: #不打印持平的结果
            Duration = i1 + i2 + i3
            if Duration == 0:
                Duration = ""
            else:
                Duration = "Duration:",i1 + i2 + i3
            if i1 != 0 or i2 != 0: #只有当连续上涨或下跌时 才会打印结果
                j_c += 1
                Log(i+1,"-- Time:",otherStyleTime,"-- High:",k_line_single.High,"-- Low:",k_line_single.Low,"--》",state_text,Duration)
    Log("运行完毕。。符合条件的总数为:",j_c)

Mais.

Zero.Obrigado por compartilhar, está em linha, o fórum é no formato markdown.

bbDesculpem, o código que enviei só foi resolvido pela metade, por isso dêem uma olhada.

QQ89520Obrigado por partilhar.

bbObrigado zero. Obrigado!