替代Matplotlib图表,动态交互python可视化:Pyecharts图表汇总

对于日常的python可视化过去用的都是Matplotlib可视化图表,但是这都是静态的图表,无法对图表进行交互。

今天介绍的pyecharts是经过网页渲染的可视化可交互的web页面图表,可以更好的时间选择或者维度选择进行交互,得到不同的动态图表。

汇总最常见的图表及代码:

1、柱状图

代码如下:

frompyechartsimportoptionsasoptsfrompyecharts.chartsimportBarfrompyecharts.commons.utilsimportJsCodefrompyecharts.globalsimportThemeTypelist2 = [{"value":12,"percent":12/ (12+3)},{"value":23,"percent":23/ (23+21)},{"value":33,"percent":33/ (33+5)},{"value":3,"percent":3/ (3+52)},{"value":33,"percent":33/ (33+43)},]list3 = [{"value":3,"percent":3/ (12+3)},{"value":21,"percent":21/ (23+21)},{"value":5,"percent":5/ (33+5)},{"value":52,"percent":52/ (3+52)},{"value":43,"percent":43/ (33+43)},]c = (Bar(init_opts=opts.InitOpts(theme=ThemeType.LIGHT)).add_xaxis([1,2,3,4,5]).add_yaxis("product1", list2, stack="stack1", category_gap="50%").add_yaxis("product2", list3, stack="stack1", category_gap="50%").set_series_opts(label_opts=opts.LabelOpts(position="right",formatter=JsCode("function(x){return Number(x.data.percent * 100).toFixed() + '%';}"),)).render("stack_bar_percent.html"))

2、折线图

代码如下:

import pyecharts.options as optsfrom pyecharts.charts import Lineweek_name_list = ["周一","周二","周三","周四","周五","周六","周日"]high_temperature = [11, 11, 15, 13, 12, 13, 10]low_temperature = [1, -2, 2, 5, 3, 2, 0](Line(init_opts=opts.InitOpts(width="1600px", height="800px")).add_xaxis(xaxis_data=week_name_list).add_yaxis(series_name="最高气温",y_axis=high_temperature,markpoint_opts=opts.MarkPointOpts(data=[opts.MarkPointItem(type_="max", name="最大值"),opts.MarkPointItem(type_="min", name="最小值"),]),markline_opts=opts.MarkLineOpts(data=[opts.MarkLineItem(type_="average", name="平均值")]),).add_yaxis(series_name="最低气温",y_axis=low_temperature,markpoint_opts=opts.MarkPointOpts(data=[opts.MarkPointItem(value=-2, name="周最低", x=1, y=-1.5)]),markline_opts=opts.MarkLineOpts(data=[opts.MarkLineItem(type_="average", name="平均值"),opts.MarkLineItem(symbol="none", x="90%", y="max"),opts.MarkLineItem(symbol="circle", type_="max", name="最高点"),]),).set_global_opts(title_opts=opts.TitleOpts(title="未来一周气温变化", subtitle="纯属虚构"),tooltip_opts=opts.TooltipOpts(trigger="axis"),toolbox_opts=opts.ToolboxOpts(is_show=True),xaxis_opts=opts.AxisOpts(type_="category", boundary_gap=False),).render("temperature_change_line_chart.html"))

3、漏斗图

代码如下:

from pyechartsimportoptions as optsfrom pyecharts.chartsimportFunnelfrom pyecharts.fakerimportFakerc= (Funnel().add("商品", [list(z)forzinzip(Faker.choose(),Faker.values())]).set_global_opts(title_opts=opts.TitleOpts(title="Funnel-基本示例")).render("funnel_base.html"))

4、仪表盘

代码如下:

frompyechartsimportoptionsasoptsfrompyecharts.chartsimportGaugec = (Gauge().add("", [("完成率",66.6)]).set_global_opts(title_opts=opts.TitleOpts(title="Gauge-基本示例")).render("gauge_base.html"))

5、地理坐标

代码如下:

from pyecharts import options as optsfrom pyecharts.charts import Geofrom pyecharts.globals import ChartType, SymbolTypec = (Geo().add_schema(maptype="china",itemstyle_opts=opts.ItemStyleOpts(color="#323c48", border_color="#111"),).add("",[("广州", 55), ("北京", 66), ("杭州", 77), ("重庆", 88)],type_=ChartType.EFFECT_SCATTER,color="white",).add("geo",[("广州","上海"), ("广州","北京"), ("广州","杭州"), ("广州","重庆")],type_=ChartType.LINES,effect_opts=opts.EffectOpts(symbol=SymbolType.ARROW, symbol_size=6, color="blue"),linestyle_opts=opts.LineStyleOpts(curve=0.2),).set_series_opts(label_opts=opts.LabelOpts(is_show=False)).set_global_opts(title_opts=opts.TitleOpts(title="Geo-Lines-background")).render("geo_lines_background.html"))

6、关系图

代码如下:

from pyechartsimportoptions as optsfrom pyecharts.chartsimportGraphnodes = [{"name":"结点1","symbolSize":10},{"name":"结点2","symbolSize":20},{"name":"结点3","symbolSize":30},{"name":"结点4","symbolSize":40},{"name":"结点5","symbolSize":50},{"name":"结点6","symbolSize":40},{"name":"结点7","symbolSize":30},{"name":"结点8","symbolSize":20},]links = []foriinnodes:forjinnodes:links.append({"source": i.get("name"),"target": j.get("name")})c= (Graph().add("", nodes, links, repulsion=8000).set_global_opts(title_opts=opts.TitleOpts(title="Graph-基本示例")).render("graph_base.html"))

7、地理坐标

代码如下:

frompyechartsimportoptionsasoptsfrompyecharts.chartsimportMapfrompyecharts.fakerimportFakerc = (Map().add("商家A", [list(z)forzinzip(Faker.provinces, Faker.values())],"china").set_global_opts(title_opts=opts.TitleOpts(title="Map-基本示例")).render("map_base.html"))

8、饼状图

代码如下:

from pyecharts import options as optsfrom pyecharts.charts import Piefrom pyecharts.faker import Fakerc = (Pie().add("", [list(z) for z in zip(Faker.choose(), Faker.values())]).set_global_opts(title_opts=opts.TitleOpts(title="Pie-基本示例")).set_series_opts(label_opts=opts.LabelOpts(formatter="{b}: {c}")).render("pie_base.html"))

9、表格图

代码如下:

frompyecharts.components import Tablefrompyecharts.options import ComponentTitleOptstable = Table()headers = ["City name","Area","Population","Annual Rainfall"]rows = [["Brisbane", 5905, 1857594, 1146.4],["Adelaide", 1295, 1158259, 600.5],["Darwin", 112, 120900, 1714.7],["Hobart", 1357, 205556, 619.5],["Sydney", 2058, 4336374, 1214.8],["Melbourne", 1566, 3806092, 646.9],["Perth", 5386, 1554769, 869.4],]table.add(headers, rows)table.set_global_opts(title_opts=ComponentTitleOpts(title="Table-基本示例", subtitle="我是副标题支持换行哦"))table.render("table_base.html")

10、时间轴图表

代码如下:

frompyechartsimportoptionsasoptsfrompyecharts.chartsimportBar, Timelinefrompyecharts.fakerimportFakerx = Faker.choose()tl = Timeline()foriinrange(2015,2020):bar = (Bar().add_xaxis(x).add_yaxis("商家A", Faker.values()).add_yaxis("商家B", Faker.values()).set_global_opts(title_opts=opts.TitleOpts("某商店{}年营业额".format(i))))tl.add(bar,"{}年".format(i))tl.render("timeline_bar.html")

11、树图

代码如下:

frompyechartsimportoptionsasoptsfrompyecharts.chartsimportTreedata = [{"children": [{"name":"B"},{"children": [{"children": [{"name":"I"}],"name":"E"}, {"name":"F"}],"name":"C",},{"children": [{"children": [{"name":"J"}, {"name":"K"}],"name":"G"},{"name":"H"},],"name":"D",},],"name":"A",}]c = (Tree().add("", data).set_global_opts(title_opts=opts.TitleOpts(title="Tree-基本示例")).render("tree_base.html"))

12、矩形树图

代码如下:

frompyechartsimportoptionsasoptsfrompyecharts.chartsimportTreeMapdata = [{"value":40,"name":"我是A"},{"value":180,"name":"我是B","children": [{"value":76,"name":"我是B.children","children": [{"value":12,"name":"我是B.children.a"},{"value":28,"name":"我是B.children.b"},{"value":20,"name":"我是B.children.c"},{"value":16,"name":"我是B.children.d"},],}],},]c = (TreeMap().add("演示数据", data).set_global_opts(title_opts=opts.TitleOpts(title="TreeMap-基本示例")).render("treemap_base.html"))

13、雷达图

代码如下:

import pyecharts.options as optsfrom pyecharts.charts import Radarv1 = [[4300, 10000, 28000, 35000, 50000, 19000]]v2 = [[5000, 14000, 28000, 31000, 42000, 21000]](Radar(init_opts=opts.InitOpts(width="1280px", height="720px", bg_color="#CCCCCC")).add_schema(schema=[opts.RadarIndicatorItem(name="销售(sales)", max_=6500),opts.RadarIndicatorItem(name="管理(Administration)", max_=16000),opts.RadarIndicatorItem(name="信息技术(Information Technology)", max_=30000),opts.RadarIndicatorItem(name="客服(Customer Support)", max_=38000),opts.RadarIndicatorItem(name="研发(Development)", max_=52000),opts.RadarIndicatorItem(name="市场(Marketing)", max_=25000),],splitarea_opt=opts.SplitAreaOpts(is_show=True, areastyle_opts=opts.AreaStyleOpts(opacity=1)),textstyle_opts=opts.TextStyleOpts(color="#fff"),).add(series_name="预算分配(Allocated Budget)",data=v1,linestyle_opts=opts.LineStyleOpts(color="#CD0000"),).add(series_name="实际开销(Actual Spending)",data=v2,linestyle_opts=opts.LineStyleOpts(color="#5CACEE"),).set_series_opts(label_opts=opts.LabelOpts(is_show=False)).set_global_opts(title_opts=opts.TitleOpts(title="基础雷达图"), legend_opts=opts.LegendOpts()).render("basic_radar_chart.html"))

14、散点图

代码如下:

import pyecharts.options as optsfrom pyecharts.charts import Scatterdata = [[10.0, 8.04],[8.0, 6.95],[13.0, 7.58],[9.0, 8.81],[11.0, 8.33],[14.0, 9.96],[6.0, 7.24],[4.0, 4.26],[12.0, 10.84],[7.0, 4.82],[5.0, 5.68],]data.sort(key=lambda x: x[0])x_data = [d[0] for d in data]y_data = [d[1] for d in data](Scatter(init_opts=opts.InitOpts(width="1600px", height="1000px")).add_xaxis(xaxis_data=x_data).add_yaxis(series_name="",y_axis=y_data,symbol_size=20,label_opts=opts.LabelOpts(is_show=False),).set_series_opts().set_global_opts(xaxis_opts=opts.AxisOpts(type_="value", splitline_opts=opts.SplitLineOpts(is_show=True)),yaxis_opts=opts.AxisOpts(type_="value",axistick_opts=opts.AxisTickOpts(is_show=True),splitline_opts=opts.SplitLineOpts(is_show=True),),tooltip_opts=opts.TooltipOpts(is_show=False),).render("basic_scatter_chart.html"))

除此之外还有桑基图、旭日图、河流图、词云图、极坐标系、象型柱图、水球图等等常用图形。

以上的图形都可以进行组合,可以通过python代码自己根据需要设计自己的动态监控大屏。

以下是我自己爬取汽车数据,设计的汽车营销BI数据监控动态大屏。

以上类型的动态大屏还可以补充更多不同类型且炫丽的动态大屏,可以根据不同的行业和分析目的设计更多酷炫的动态大屏。

--END--

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 213,335评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,895评论 3 387
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 158,766评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,918评论 1 285
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,042评论 6 385
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,169评论 1 291
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,219评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,976评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,393评论 1 304
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,711评论 2 328
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,876评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,562评论 4 336
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,193评论 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,903评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,142评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,699评论 2 362
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,764评论 2 351

推荐阅读更多精彩内容