锤头本篇接着上篇介绍K线形态。
首先,我们今天介绍的第一个K线形态是锤头,TA-Lib库提供给我们的方法为talib.CDLHAMMER(),它是一日K线形态,实体较短,无上影线,同时下影线大于实体长度的两倍,预示着趋势反转。
完整绘制标记锤头的代码如下:
- import matplotlib.pyplot as plt
复制代码- import matplotlib.ticker as ticker
复制代码- import mpl_finance as mpf
复制代码- fig = plt.figure(figsize=(12, 8))
复制代码- plt.rcParams['font.sans-serif'] = ['SimHei']
复制代码- ax = fig.add_subplot(111)
复制代码- df = pd.read_excel("歌尔股份year.xlsx")
复制代码- df['date'] = pd.to_datetime(df['date'])
复制代码- df['date'] = df['date'].apply(lambda x: x.strftime('%Y-%m-%d'))
复制代码- df['hammer_head'] = talib.CDLHAMMER(df['open'].values, df['high'].values, df['low'].values, df['close'].values)
复制代码- pattern = df[(df['hammer_head'] == 100) | (df['hammer_head'] == -100)]
复制代码- mpf.candlestick2_ochl(ax, df["open"], df["close"], df["high"], df["low"], width=0.6, colorup='r',
复制代码- for key, val in df.items():
复制代码- for index, today in pattern.iterrows():
复制代码- x_posit = df.index.get_loc(index)
复制代码- ax.annotate("{}\n{}".format("锤头", today["date"]), xy=(x_posit, today["high"]),
复制代码- xytext=(0, pattern["close"].mean()), xycoords="data",
复制代码- fontsize=18, textcoords="offset points", arrowprops=dict(arrowstyle="simple", color="r"))
复制代码- ax.xaxis.set_major_locator(ticker.MaxNLocator(20))
复制代码- def format_date(x, pos=None):
复制代码- if x len(df['date']) - 1:
复制代码- return df['date'][int(x)]
复制代码- ax.xaxis.set_major_formatter(ticker.FuncFormatter(format_date))
复制代码- plt.setp(plt.gca().get_xticklabels(), rotation=45, horizontalalignment='right')
复制代码 锤头的形态很多股票都有,你可以随便自己找股票测试,这里还是用的歌尔股份。运行之后,显示效果如下图所示:
在这里插入图片描述
倒锤头既然有正锤头,那么肯定也有倒锤头,TA-Lib库提供给我们的方法为talib.CDLINVERTEDHAMMER(),它也是一日K线,定义为上影线较长,长度为实体的2倍以上,无下影线,在下跌趋势底部,预示着趋势反转。
既然上面完整代码都有,这里同上一篇博文一样,只需要更换二行代码:
- df['Inverted_hammer_head'] = talib.CDLHAMMER(df['open'].values, df['high'].values, df['low'].values, df['close'].values)
复制代码- pattern = df[(df['Inverted_hammer_head'] == 100) | (df['Inverted_hammer_head'] == -100)]
复制代码 同时还要更改文字标识“锤头”为“倒锤头”,运行之后效果如下图所示:
在这里插入图片描述
射击之星射击之星是一日K线模式,定义为上影线至少为实体长度的2倍,同时没有下影线,预示着股票下跌。TA-Lib库提供给我们的方法为talib.CDLSHOOTINGSTAR()。
同样的,射击之星的代码也只需要更换2行:
- df['shoot_star'] = talib.CDLSHOOTINGSTAR(df['open'].values, df['high'].values, df['low'].values, df['close'].values)
复制代码- pattern = df[(df['shoot_star'] == 100) | (df['shoot_star'] == -100)]
复制代码 运行之后,显示的效果如下图所示:
在这里插入图片描述
早晨之星早晨之星为三日K线模式,定义为下跌趋势,第一日为阴线,第二日价格振幅较小,第三天阳线,预示着底部可能会有反转。TA-Lib库提供给我们的方法为talib.CDLMORNINGSTAR()。
同样的,早晨之星的代码也只需要更换2行:
- df['morning_star'] = talib.CDLMORNINGSTAR(df['open'].values, df['high'].values, df['low'].values, df['close'].values)
复制代码- pattern = df[(df['morning_star'] == 100) | (df['morning_star'] == -100)]
复制代码 运行之后,显示的效果如下图所示:
在这里插入图片描述当然,对于K线图的指标其实还有很多,比如上吊线方法CDLHANGINGMAN、倒T十字CDLGRAVESTONEDOJI、向上/下跳空并列阳线CDLGAPSIDESIDEWHITE等,使用方式与这2篇博文完全一样、只是替换了方法。所以,为了不讲解毫无营养的股票量化交易,其他的指标博主这里省略了,具体你需要哪个指标,自己查询开发文档直接按这2篇调用即可。
|
|