python股票量化交易(8)---K线图:锤头,射击之星,早晨之星

论坛 期权论坛 期权     
一天一篇Python库   2021-5-9 11:58   6425   0
锤头本篇接着上篇介绍K线形态。
首先,我们今天介绍的第一个K线形态是锤头,TA-Lib库提供给我们的方法为talib.CDLHAMMER(),它是一日K线形态,实体较短,无上影线,同时下影线大于实体长度的两倍,预示着趋势反转。
完整绘制标记锤头的代码如下:
  1. import pandas as pd
复制代码
  1. import talib
复制代码
  1. import matplotlib.pyplot as plt
复制代码
  1. import matplotlib.ticker as ticker
复制代码
  1. import mpl_finance as mpf
复制代码
  1. fig = plt.figure(figsize=(12, 8))
复制代码
  1. plt.rcParams['font.sans-serif'] = ['SimHei']
复制代码
  1. ax = fig.add_subplot(111)
复制代码
  1. df = pd.read_excel("歌尔股份year.xlsx")
复制代码
  1. df['date'] = pd.to_datetime(df['date'])
复制代码
  1. df['date'] = df['date'].apply(lambda x: x.strftime('%Y-%m-%d'))
复制代码
  1. df['hammer_head'] = talib.CDLHAMMER(df['open'].values, df['high'].values, df['low'].values, df['close'].values)
复制代码
复制代码
  1. pattern = df[(df['hammer_head'] == 100) | (df['hammer_head'] == -100)]
复制代码
  1. mpf.candlestick2_ochl(ax, df["open"], df["close"], df["high"], df["low"], width=0.6, colorup='r',
复制代码
  1.                           colordown='green',
复制代码
  1.                           alpha=1.0)
复制代码
  1. for key, val in df.items():
复制代码
  1.     for index, today in pattern.iterrows():
复制代码
  1.         x_posit = df.index.get_loc(index)
复制代码
  1.         ax.annotate("{}\n{}".format("锤头", today["date"]), xy=(x_posit, today["high"]),
复制代码
  1.                     xytext=(0, pattern["close"].mean()), xycoords="data",
复制代码
  1.                     fontsize=18, textcoords="offset points", arrowprops=dict(arrowstyle="simple", color="r"))
复制代码
复制代码
复制代码
  1. ax.xaxis.set_major_locator(ticker.MaxNLocator(20))
复制代码
复制代码
  1. def format_date(x, pos=None):
复制代码
  1.     if x  len(df['date']) - 1:
复制代码
  1.         return ''
复制代码
  1.     return df['date'][int(x)]
复制代码
复制代码
复制代码
  1. ax.xaxis.set_major_formatter(ticker.FuncFormatter(format_date))
复制代码
  1. plt.setp(plt.gca().get_xticklabels(), rotation=45, horizontalalignment='right')
复制代码
  1. plt.show()
复制代码
锤头的形态很多股票都有,你可以随便自己找股票测试,这里还是用的歌尔股份。运行之后,显示效果如下图所示:

在这里插入图片描述

倒锤头既然有正锤头,那么肯定也有倒锤头,TA-Lib库提供给我们的方法为talib.CDLINVERTEDHAMMER(),它也是一日K线,定义为上影线较长,长度为实体的2倍以上,无下影线,在下跌趋势底部,预示着趋势反转。
既然上面完整代码都有,这里同上一篇博文一样,只需要更换二行代码:
  1. df['Inverted_hammer_head'] = talib.CDLHAMMER(df['open'].values, df['high'].values, df['low'].values, df['close'].values)
复制代码
复制代码
  1. pattern = df[(df['Inverted_hammer_head'] == 100) | (df['Inverted_hammer_head'] == -100)]
复制代码
同时还要更改文字标识“锤头”为“倒锤头”,运行之后效果如下图所示:

在这里插入图片描述

射击之星射击之星是一日K线模式,定义为上影线至少为实体长度的2倍,同时没有下影线,预示着股票下跌。TA-Lib库提供给我们的方法为talib.CDLSHOOTINGSTAR()。
同样的,射击之星的代码也只需要更换2行:
  1. df['shoot_star'] = talib.CDLSHOOTINGSTAR(df['open'].values, df['high'].values, df['low'].values, df['close'].values)
复制代码
复制代码
  1. pattern = df[(df['shoot_star'] == 100) | (df['shoot_star'] == -100)]
复制代码
运行之后,显示的效果如下图所示:

在这里插入图片描述

早晨之星早晨之星为三日K线模式,定义为下跌趋势,第一日为阴线,第二日价格振幅较小,第三天阳线,预示着底部可能会有反转。TA-Lib库提供给我们的方法为talib.CDLMORNINGSTAR()。
同样的,早晨之星的代码也只需要更换2行:
  1. df['morning_star'] = talib.CDLMORNINGSTAR(df['open'].values, df['high'].values, df['low'].values, df['close'].values)
复制代码
复制代码
  1. pattern = df[(df['morning_star'] == 100) | (df['morning_star'] == -100)]
复制代码
运行之后,显示的效果如下图所示:
在这里插入图片描述当然,对于K线图的指标其实还有很多,比如上吊线方法CDLHANGINGMAN、倒T十字CDLGRAVESTONEDOJI、向上/下跳空并列阳线CDLGAPSIDESIDEWHITE等,使用方式与这2篇博文完全一样、只是替换了方法。所以,为了不讲解毫无营养的股票量化交易,其他的指标博主这里省略了,具体你需要哪个指标,自己查询开发文档直接按这2篇调用即可。


分享到 :
0 人收藏
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

积分:63
帖子:2
精华:0
期权论坛 期权论坛
发布
内容

下载期权论坛手机APP