python:pyecharts 画基金净值 月K线图

pip install pyecharts==1.9.1

 pyecharts-1.9.1-py3-none-any.whl

我想在本地(PC) 画出 基金净值 月K线图,不想每次看图都需联网。

cd my_dir
mkdir echarts
cd echarts
curl -O https://assets.pyecharts.org/assets/echarts.min.js

修改一下开源代码

cd \Python38\Lib\site-packages\pyecharts\  编辑 globals.py 第125行
class _OnlineHost:
    DEFAULT_HOST = "https://assets.pyecharts.org/assets/"

改为 DEFAULT_HOST = "./echarts/"

编写  kline_m.py  如下

# coding=utf-8
import os, sys
from pyecharts import options as opts
from pyecharts.charts import Kline, Line

if len(sys.argv) ==2:
    fcode = sys.argv[1]
    file1 = 'M'+fcode +'.csv'
    file2 = 'M'+fcode +'.htm'
elif len(sys.argv) ==3:
    fcode = sys.argv[1]
    file1 = 'M'+fcode +'_'+sys.argv[2]+'.csv'
    file2 = 'M'+fcode +'_'+sys.argv[2]+'.htm'
else:
    print('usage: kline_m.py fcode ')
    sys.exit(1)

if len(fcode) !=6:
    print(' fcode is char(6)')
    sys.exit(2)

#file1 = 'M'+fcode +'.csv'
#file2 = 'M'+fcode +'.htm'
path ='./data/'
if not os.path.exists(path+file1):
    print(file1 +' is not exists.')
    sys.exit(3)

# 定义K线图的数据:['open','close','low','high'] 
# 数据项: [open,close,low,high,mavg] 
#  (即:[开盘值,收盘值,最低值,最高值,平均值])
xlist = []
ylist = []
clist = []
fr = open(path+file1, 'r')
fr.readline() # 跳过第1行表头: ym,open,close,low,high,mavg
for line in fr:
    ym,open,close,low,high,mavg = line.strip().split(',')
    xlist.append(ym)
    ylist.append([open,close,low,high])
    clist.append(mavg)
fr.close()    
print(str(len(xlist)))
if len(sys.argv) ==2:
    title = fcode+" 基金净值 月K线图"
elif len(sys.argv) ==3:
    title = fcode+" 累计净值 月K线图"

# 创建一个K线图实例
kline = Kline(init_opts=opts.InitOpts(width="1200px", height="600px"))

# 设置x轴的数据
kline.add_xaxis(xlist)

# 设置y轴的数据,这里的 "kline" 是系列名称,data 是K线图的数据
kline.add_yaxis("kline", ylist)

# 设置全局配置项,包括x轴、y轴、标题等配置
kline.set_global_opts(
    xaxis_opts=opts.AxisOpts(is_scale=True),  # 设置x轴的刻度是否自适应
    yaxis_opts=opts.AxisOpts(is_scale=True,   
        splitarea_opts=opts.SplitAreaOpts(is_show=True,
            areastyle_opts=opts.AreaStyleOpts(opacity=1))
    ),
    datazoom_opts=[opts.DataZoomOpts()],
    title_opts=opts.TitleOpts(title=title),   # 设置标题
)
# 平均线,还可以加多条线
line1 = Line().add_xaxis(xlist).add_yaxis('mavg', clist, yaxis_index=0)
line1.set_series_opts(
            label_opts=opts.LabelOpts(is_show=False),
            linestyle_opts=opts.LineStyleOpts(width=2),
        )
kline.overlap(line1)

kline.render(path='./html/'+ file2)

运行 python kline_m.py 660008

生成 M660008.html

参考:pyecharts绘制K线图,并添加辅助线

  • 9
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值