利用本地csv文件绘制股票走势图(pyercharts)

很多股票数据都是csv文件的,当然也可以利用excel文件另存为csv即可;

笔者近期结合工作情况,利用本地csv文件绘制股票走势图。

首先下载需要的数据,如沪深300指数和中证500指数数据:

 

最后成图:

 

 

 

#!/usr/bin/python3

#导入需要的包
import csv
from pyecharts import options as opts
from pyecharts.charts import Line

#文件地址
f1 = 'C:\\Users\\Administrator\\Desktop\\test\\指数行情_000300.csv'
f2 = 'C:\\Users\\Administrator\\Desktop\\test\\指数行情_000905.csv'

#创建空列表
t1 = []
t2 = []
t3 = []

#读取其中一个文件
with open(f1, 'r',newline='',encoding='utf-8') as f:
    reader = csv.reader(f)
    
    header = next(reader)    
    print(header) #打印表头

 

 

 

 

 逐行读取数据,并添加到列表中:

 

 

 

    for i in reader:
        t1.append(i[2]) #添加到列表,append() 方法用于在列表末尾添加新的对象,语法:list.append()
        t2.append(i[6])

with open(f2, 'r',newline='',encoding='utf-8') as f:
    reader = csv.reader(f)
    for j in reader:
        t3.append(j[6])

 

直接画图:

 

c = (
    Line()
    .add_xaxis(t1)
    .add_yaxis("沪深300", t2)
    .add_yaxis("中证500", t3)

    .set_global_opts(
        title_opts=opts.TitleOpts(title="沪深300VS中证500",subtitle="我是副标题"),
        tooltip_opts=opts.TooltipOpts(trigger="axis"),
        datazoom_opts=[opts.DataZoomOpts(), opts.DataZoomOpts(type_="inside")],
    )    
    .render("line.html")
)
    

 

 

 

有时,列表的顺序会颠倒,这时需要我们进行转换,reverse() 函数用于反向列表中元素,语法:list.reverse(),转换后再绘图:

 

t1.reverse()
t2.reverse()
t3.reverse()

c = (
    Line()
    .add_xaxis(t1)
    .add_yaxis("沪深300", t2)
    .add_yaxis("中证500", t3)

    .set_global_opts(
        title_opts=opts.TitleOpts(title="沪深300VS中证500",subtitle="我是副标题"),
        tooltip_opts=opts.TooltipOpts(trigger="axis"),
        datazoom_opts=[opts.DataZoomOpts(), opts.DataZoomOpts(type_="inside")],
    )    
    .render("line.html")
)

 

 

 时间和数据正确。

 

次例难点还在于基础,csv和list包熟悉运用,csv读取时,是每行的进行读取,需要把所得到的数据增至一个新的列表才能完整显示,不然只能显示最后一个数据

 

当然,我们大多数需要的是比值,而非单纯的数据,目前小编还没做好比值的图,欢迎各位大神指点!

 

posted @ 2021-12-24 17:23  徐海建  阅读(1242)  评论(0编辑  收藏  举报