精易论坛

标题: 用python事移动平均线 [打印本页]

作者: yuanqun    时间: 2017-8-3 11:57
标题: 用python事移动平均线
import pandas as pd
import tushare as ts
import numpy as np
import datetime
import matplotlib.pyplot as plt
from matplotlib.dates import date2num
from matplotlib.finance import candlestick_ohlc

def 画收盘价曲线(code):
    start =str(datetime.date(2017,1,1))
    end = str(datetime.date.today())
    dates=ts.get_k_data(code,start,end,'d')
    df = pd.DataFrame(dates,columns=list(["date","open","close","high","low","volume","code"]))
    plt.plot(df['close'])
    df['20d']=np.round(df["close"].rolling(window=20, center=False).mean(), 2)
    plt.plot(df['20d'])#画20天均线
    plt.show()

def 画K线图(code):
    start = str(datetime.date(2017, 3, 1))
    end = str(datetime.date.today())
    dates = ts.get_h_data(code, start, end)
    dates=dates.shift(90,freq='H')
    width=0.6
    fig=plt.figure()#创建一幅图
    ax1=plt.subplot2grid((4,4),(0,0),rowspan=3,colspan=4)
    ohlc=zip(dates.index.map(date2num),dates['open'],dates['high'],dates['low'],dates['close'])
    candlestick_ohlc(ax1,ohlc,width=width,colorup='#77d879',colordown='#db3f3f')
    dates['20d']=pd.rolling_mean(dates['close'],20)
    plt.plot(dates['20d'])  # 画20天均线
    plt.grid(True)
    ax2 = plt.subplot2grid((4,4),(3,0),rowspan=1,colspan=4)
    ax2.bar(dates.index.map(date2num),dates['volume']/10000,width=width,align='center')
    plt.grid(True)
    ax1.set_title(code)
    ax1.set_ylabel('price')
    ax2.set_ylabel("Volume(ten thousand)")
    plt.show()
画K线图('600028')
不知道为什么这画均线与K线不对应


作者: 桃花仙人    时间: 2017-8-3 14:14
你是我看到的第一个用汉字做PYthon函数名的,老哥稳!
作者: huyifei    时间: 2017-8-27 00:00
哈哈,要是有易语言那有输入方便的话,其实也无所谓的。
作者: wolfpack    时间: 2024-6-20 23:05
。。。。。。。。。。。。。。




欢迎光临 精易论坛 (https://125.confly.eu.org/) Powered by Discuz! X3.4