echart 柱状图series label 不超过屏幕_柱状图还是那个柱状图,但是它得灵魂变了。它又回来了...

本文的文字及图片来源于网络,仅供学习、交流使用,不具有任何商业用途,,版权归原作者所有,如有问题请及时联系我们以作处理

本篇文章来自腾讯云 作者:数据山谷

私信小编01即可获取大量Python学习资料

先给大家展现给不一样得东西看看。

e01298b7c699079dda27ccf200f34f51.png
ea3ffdaf09091efccc2ee3e6d27e6e51.png

导包

# 导入options配置项from pyecharts import options as opts# 导入柱状图,时间轴from pyecharts.charts import Bar,Timeline# 导入Faker随机生成标签from pyecharts.faker import Faker# 使用random随机生成数值import random

首先我们随机生成x轴数据

phone=Faker.phones

开头展示的柱状图熟悉么?

tl = Timeline()# 写一个时间轴函数def timeline_bar() -> Timeline:    for i in range(2015, 2020):        data1=random.sample(range(0, 100), 7)         data2=random.sample(range(0, 100), 7)        bar=Bar()        bar.add_xaxis(phone)        bar.add_yaxis('A店',data1)        bar.add_yaxis('B店',data2)        bar.set_global_opts(title_opts=opts.TitleOpts(.format(i),sub))        tl.add(bar, "{}年".format(i))    return tltimeline_bar().render_notebook()

添加数据标签和辅助线之后的时间轴展示

tl = Timeline()def timeline_bar() -> Timeline:    for i in range(2015, 2020):        data1=random.sample(range(10, 100), 7)         data2=random.sample(range(10, 100), 7)        bar=(Bar()             .add_xaxis(phone)             .add_yaxis('A店',data1)             .add_yaxis('B店',data2)             .set_global_opts(title_opts=opts.TitleOpts(.format(i),sub),                                                       legend_opts=opts.LegendOpts(is_show=True)                     )             .set_series_opts(label_opts=opts.LabelOpts(is_show=True),                              markpoint_opts=opts.MarkPointOpts(data=[opts.MarkPointItem(type_='max',name='最大值')]),                              markline_opts=opts.MarkLineOpts(data=[opts.MarkPointItem(type_='min',name='最小值')])                    )    )        tl.add(bar, "{}年".format(i))    return tl  timeline_bar().render_notebook()

效果

87d36b3bb2f452e3547919946e77e78b.png

变换之后得效果展示

tl = Timeline()def timeline_bar() -> Timeline:    for i in range(2015, 2020):        data1=random.sample(range(10, 100), 7)         data2=random.sample(range(10, 100), 7)        bar=(Bar()             .add_xaxis(phone)             .add_yaxis('A店',data1,stack="stack1", category_gap="50%")             .add_yaxis('B店',data2, stack="stack1", category_gap="50%")             .set_global_opts(title_opts=opts.TitleOpts(.format(i),sub),                              legend_opts=opts.LegendOpts(is_show=True),                                          )             .set_series_opts(label_opts=opts.LabelOpts(is_show=True),                              markpoint_opts=opts.MarkPointOpts(data=[opts.MarkPointItem(type_='max',name='最大值')]),                              markline_opts=opts.MarkLineOpts(data=[opts.MarkPointItem(type_='min',name='最小值')])                       )             .reversal_axis()    )        tl.add(bar, "{}年".format(i))    return tl  timeline_bar().render_notebook()

效果

0e9c15858b7c38288c43bf6cb1e5babd.png

再来看看堆积柱状图的样子!

tl = Timeline()def timeline_bar() -> Timeline:    for i in range(2015, 2020):        data1=random.sample(range(10, 100), 7)         data2=random.sample(range(10, 100), 7)        bar=(Bar()             .add_xaxis(phone)             .add_yaxis('A店',data1,stack="stack1", category_gap="50%")             .add_yaxis('B店',data2, stack="stack1", category_gap="50%")             .set_global_opts(title_opts=opts.TitleOpts(.format(i),sub),                              legend_opts=opts.LegendOpts(is_show=True),                                          )             .set_series_opts(label_opts=opts.LabelOpts(is_show=True),                              markpoint_opts=opts.MarkPointOpts(data=[opts.MarkPointItem(type_='max',name='最大值')]),                              markline_opts=opts.MarkLineOpts(data=[opts.MarkPointItem(type_='min',name='最小值')])                    )    )        tl.add(bar, "{}年".format(i))    return tl  timeline_bar().render_notebook()

效果

8abd0c724696df111f1f8ff1d2a1e40b.png


给大家介绍一位新朋友!!!

# 导入3D柱状图的包from pyecharts.charts import Bar3D# 随机生成x.y.z轴数据phone=Faker.phonesdays =Faker.week_endata = [(i, j, random.randint(0,20)) for i in range(7) for j in range(7)]bar3d=Bar3D(init_opts=opts.InitOpts(, ))bar3d.add(        series_name="",        data=data,        xaxis3d_opts=opts.Axis3DOpts(type_="category", data=phone),        yaxis3d_opts=opts.Axis3DOpts(type_="category", data=days),        zaxis3d_opts=opts.Axis3DOpts(type_="value"),    )bar3d.set_global_opts(        visualmap_opts=opts.VisualMapOpts(            max_=25        )    )bar3d.render_notebook()
cfa6d159bf9565134afab10a3465eb74.png


细心地小伙伴今天可能已经发现了,我们的代码是用链式法写的,这样的简便写法大家尝试一下

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值