pyecharts 是一个用于生成 Echarts 图表的类库。 html
echarts 是百度开源的一个数据可视化 JS 库,主要用于数据可视化。pyecharts 是一个用于生成 Echarts 图表的类库。实际上就是 Echarts 与 Python 的对接。python
使用 pyecharts 能够生成独立的网页,也能够在 flask , Django 中集成使用。git
Bar(柱状图/条形图)
Bar3D(3D 柱状图)
Boxplot(箱形图)
EffectScatter(带有涟漪特效动画的散点图)
Funnel(漏斗图)
Gauge(仪表盘)
Geo(地理坐标系)
Graph(关系图)
HeatMap(热力图)
Kline(K线图)
Line(折线/面积图)
Line3D(3D 折线图)
Liquid(水球图)
Map(地图)
Parallel(平行坐标系)
Pie(饼图)
Polar(极坐标系)
Radar(雷达图)
Sankey(桑基图)
Scatter(散点图)
Scatter3D(3D 散点图)
ThemeRiver(主题河流图)
WordCloud(词云图)
用户自定义
Grid 类:并行显示多张图
Overlap 类:结合不一样类型图表叠加画在同张图上
Page 类:同一网页按顺序展现多图
Timeline 类:提供时间线轮播多张图
1 pip install pyecharts
这里要专门说明一下,自从 0.3.2 开始,为了缩减项目自己的体积以及维持 pyecharts 项目的轻量化运行,pyecharts 将再也不自带地图 js 文件。如用户须要用到地图图表(Geo、Map),可自行安装对应的地图文件包。
不然在用到这两个包的时候,并能完整的显示地图效果。
Windows下经过已下的pip命令进行安装github
1 pip install echarts-countries-pypkg 2 3 pip install echarts-china-provinces-pypkg 4 5 pip install echarts-china-cities-pypkg
Linux下经过如下的pip命令进行安装
1 sudo pip3 install echarts-countries-pypkg 2 3 4 sudo pip3 install echarts-china-provinces-pypkg 5 6 7 sudo pip3 install echarts-china-cities-pypkg 8 9 10 sudo pip3 install echarts-countries-pypkg 11 12 13 sudo pip3 install echarts-china-provinces-pypkg 14 15 16 sudo pip3 install echarts-china-cities-pypkg
先介绍一些可能会用到的基本函数:数据库
add() 主要方法,用于添加图表的数据和设置各类配置项flask
show_config() 打印输出图表的全部配置项api
render() 默认将会在根目录下生成一个 render.html 的文件,支持 path 参数,设置文件保存位置,如 render(r"e:my_first_chart.html"),文件用浏览器打开。浏览器
默认的编码类型为 UTF-8,在 Python3 中是没什么问题的,Python3 对中文的支持好不少。可是在 Python2 中,编码的处理是个很头疼的问题,暂时没能找到完美的解决方法,目前只能经过文本编辑器本身进行二次编码,我用的是 Visual Studio Code,先经过 Gbk 编码从新打开,而后再用 UTF-8 从新保存,这样用浏览器打开的话就不会出现中文乱码问题了。(这里是某位大佬遇到的问题,我直接复制过来了,供你们参考)app
基本上全部的图表类型都是这样绘制的:echarts
chart_name = Type() 初始化具体类型图表。
add() 加数据及配置项。
render() 生成 .html 文件。
1 from pyecharts import Bar 2 bar =Bar("个人第一个图表", "这里是副标题") 3 bar.add("服装", ["衬衫", "羊毛衫", "雪纺衫", "裤子", "高跟鞋", "袜子"], [5, 20, 36, 10, 75, 90]) 4 bar.show_config() 5 bar.render()
from pyecharts import Bar bar =Bar("x 轴和 y 轴交换") bar.add("商家A", attr, v1) bar.add("商家B", attr, v2, is_convert=True) bar.render()
说明:以下代码,atf_tb1属性是并不会显示在图表中的
1 bar = Bar() 2 bar.add('格式化',["atf_tb1","shop"],[10,50]) 3 bar.add("范围", ["shop"], [120]) 4 bar.render()
能够看到atf_tb1并无加载到图表中,说明并不支持这么使用
1 from pyecharts import Pie 2 attr =["衬衫", "羊毛衫", "雪纺衫", "裤子", "高跟鞋", "袜子"] 3 v1 =[11, 12, 13, 10, 10, 10] 4 pie =Pie("饼图示例") 5 pie.add("", attr, v1, is_label_show=True) 6 pie.show_config() 7 pie.render()
1 from pyecharts import WordCloud 2 name =['Sam S Club', 'Macys', 'Amy Schumer', 'Jurassic World', 'Charter Communications', 'Chick Fil A', 'Planet Fitness', 'Pitch Perfect', 'Express', 'Home', 'Johnny Depp', 'Lena Dunham', 'Lewis Hamilton', 'KXAN', 'Mary Ellen Mark', 'Farrah Abraham', 'Rita Ora', 'Serena Williams', 'NCAA baseball tournament', 'Point Break'] 3 value =[10000, 6181, 4386, 4055, 2467, 2244, 1898, 1484, 1112, 965, 847, 582, 555, 550, 462, 366, 360, 282, 273, 265] 4 wordcloud =WordCloud(width=1300, height=620) 5 wordcloud.add("", name, value, word_size_range=[20, 100]) 6 wordcloud.show_config() 7 wordcloud.render()
词云图的形状能够经过shape参数来选择
1 wordcloud =WordCloud(width=1300, height=620) 2 wordcloud.add("", name, value, word_size_range=[30, 100], shape='diamond') 3 wordcloud.show_config() 4 wordcloud.render()
1 from pyecharts import Geo 2 data =[("海门", 9), ("鄂尔多斯", 12), ("招远", 12), ("舟山", 12), ("齐齐哈尔", 14), ("盐城", 15)] 3 geo =Geo("全国主要城市空气质量", "data from pm2.5", title_color="#fff", title_pos="center", width=1200, height=600, background_color='#404a59') 4 attr, value =geo.cast(data) 5 geo.add("", attr, value, type="effectScatter", is_random=True, effect_scale=5) 6 geo.show_config() 7 geo.render()
这里也要先说明一点由于echarts里面有的地点可能没有,一旦添加了没有的在这里面,将会生成一个空的图。
有四个解决办法:
一是最简单的把不存在删掉;
二是到百度地图api里把找不到的地方的经纬度加进原始的包里(这个办法你们能够参看这位大佬的博客https://blog.csdn.net/summerstones/article/details/78078789);
三是若是你的数据在地图中并无坐标城市,能够经过 geo_cities_coords 本身进行添加,GeoLine图一样如此
1 #!/usr/bin/env python 2 # -*- coding:utf-8 -*- 3 # Author: jyroy 4 from pyecharts import Geo 5 6 if __name__ == '__main__': 7 8 list_city_name=["100,30-1","130,40-2"] 9 list_num = [["value1","value2"],["value3"]] 10 geo_cities_coords = {"100,30-1":[100,30],"130,40-2":[130,40]} 11 12 geo = Geo("Geo 实例") 13 geo.add("",list_city_name, list_num, geo_cities_coords=geo_cities_coords) 14 geo.render()
四是若是你是批量的导入导入数据(相似从数据库中),异常数据并不想插入到地图中去,能够经过try...except...来清除这少部分的异常数据,以下代码,这是我本身遇到的问题的想到的一个解决办法,data是我从数据库中获得的字典
固然若是数据量比较大的话,这样作效率可能不高,给你们一个参考吧
for n, m in data.items(): #data是我从数据库中读取的城市的字典数据 list_1 = [] list_2 = [] list_1.append(n) list_2.append(m) try: geo.add("", list_1, list_2, visual_range=[0, 3000], visual_text_color="#fff", symbol_size=15, is_visualmap=True) except Exception as e: pass
固然若是数据量比较大的话,这样作效率可能不高,给你们一个参考吧这是个人项目里一部分的数据获得的结果,我拿了7万多条数据来作的测试,感受效果还ok
1 from pyecharts import Line 2 attr =["衬衫", "羊毛衫", "雪纺衫", "裤子", "高跟鞋", "袜子"] 3 v1 =[5, 20, 36, 10, 10, 100]v2 =[55, 60, 16, 20, 15, 80] 4 line =Line("折线图示例") 5 line.add("商家A", attr, v1, mark_point=["average"]) 6 line.add("商家B", attr, v2, is_smooth=True, mark_line=["max", "average"]) 7 line.show_config() 8 line.render()
1 line =Line("折线图-面积图示例") 2 line.add("商家A", attr, v1, is_fill=True, line_opacity=0.2, area_opacity=0.4, symbol=None) 3 line.add("商家B", attr, v2, is_fill=True, area_color='#000', area_opacity=0.3, is_smooth=True) 4 line.show_config() 5 line.render()
由于我在用的过程当中都是结合数据库批量处理的,因此就不把我写的全都放上了,这有上面地图那里第三个解决办法放了一部分我本身的代码,其余的都是网上常见的一些测试用例。
这里都是基础的介绍(我认为可能经常使用的一些图表),想了解更多的关于pyecharts的,就不推荐其余人的博客了,都大同小异,你们仍是移步官网 http://pyecharts.org/#/zh-cn/ ,由于这是个开源的项目,pyecharts也是三我的一直在维护的,官网内容很是丰富,并且有中文版。
有想了解我本身作的实例的,欢迎Q我(看博客侧边栏~)
大佬们支持一下!点下推荐和关注吧~~