Python入门简单小脚本-统计单边连续行情

Author: bb, Created: 2018-07-23 15:53:45, Updated: 2018-07-24 12:27:27

最近在学量化,也没啥基础,敲点东西慢慢来。

今天敲了个小脚本用于统计最近50天(貌似平台用OK模拟回测只能50天?)的单边行情(连续上涨或连续下跌)出现次数。 本来是想写个↓ 《识别震荡与趋势,真的很简单!》 https://www.fmz.cn/bbs-topic/1638 利用后一周期的新低来对比此周期的新高,这种思想来判断趋势的。上行和下行趋势都可以用。 感谢作者发的这个文章,但我在测试时,设置K线周期,最多只能回测50天,设置时间段也没用,所以缺少数据支撑设想。

运行效果如下:

img

输出顺序为:id——>Time——>阶段最高价——>阶段最低价——>涨跌状态——>持续次数

  • 过滤了单次涨跌及持平行情 如:涨——>跌——>涨——>平——>跌——>平——>涨——>这种没用连续性的状态不打印,对分析没啥帮助。
  • 使用下一周期最高价与此周期最高价对比,也可以用下一周期的.Low与此周期.High对比,像上文那样。
  • 回测获取的行情时间真是尴尬,比如3分钟线 就是00:57——>01:00——>01:57——>02:00——>02:57…为什么???
  • 要求别太高哦,不会写Python。

有啥用?

  • 我觉得挺有用的,起码比闲着好,但时间周期太短,也看不出啥规律。
  • 不过如果目前我们在的行情,按照日线来看,已连续出现单边上涨行情12天,大家说第13天上涨的几率就多大??
  • 我就是揣着这个想法来做这个测试的,不尽人意,还要变通思路试下去。。
  • 欢迎交流,我是正在正常的菜鸟。

下面是精简了些的代码


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)

再来一个没有精简后的代码——效果一样的,比上面的多了21行代码

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)

More

Zero 谢谢分享, 排了个版, 论坛是markdown格式

bb 对不起,我发的代码只解析了一半,凑合瞧吧。。

qq89520 谢谢分享

bb 谢谢零度 谢谢!