3---条形图(matplotlib)

案例1-----竖着的条形图(matplotlib)
'''
竖着的条形图:plt.bar(x,y,width=0.2)
假如你获取到了2017年内地电影票房前20的电影(列表a)和电影票房数据(列表b),那么如何更加直观的展示该数据?
a = ["战狼2","速度与激情8","功夫瑜伽","西游伏妖篇","变形金刚5:最后的骑士","摔跤吧!爸爸","加勒比海盗5:死无对证","金刚:骷髅岛","极限特工:终极回归","生化危机6:终章","乘风破浪","神偷奶爸3","智取威虎山","大闹天竺","金刚狼3:殊死一战","蜘蛛侠:英雄归来","悟空传","银河护卫队2","情圣","新木乃伊",]
b =[56.01,26.94,17.53,16.49,15.45,12.96,11.8,11.61,11.28,11.12,10.49,10.3,8.75,7.55,7.32,6.99,6.88,6.86,6.58,6.23]
'''
from matplotlib import pyplot as plt
from matplotlib import font_manager
my_font = font_manager.FontProperties(fname='c:\Windows\Fonts\FZSTK.TTF')

x = ["战狼2","速度与激情8","功夫瑜伽","西游伏妖篇","变形金刚5:最后的骑士","摔跤吧!爸爸","加勒比海盗5:死无对证","金刚:骷髅岛","极限特工:终极回归","生化危机6:终章","乘风破浪","神偷奶爸3","智取威虎山","大闹天竺","金刚狼3:殊死一战","蜘蛛侠:英雄归来","悟空传","银河护卫队2","情圣","新木乃伊",]
y =[56.01,26.94,17.53,16.49,15.45,12.96,11.8,11.61,11.28,11.12,10.49,10.3,8.75,7.55,7.32,6.99,6.88,6.86,6.58,6.23]
plt.figure(figsize=(20,8),dpi=80)

# 绘制条形图
plt.bar(range(len(x)), y, width=0.3)

# 调整x轴刻度
_x = range(len(x))
_xtick_labels = x
plt.xticks(_x,_xtick_labels,fontproperties=my_font,rotation=90)

plt.savefig('./movie.png')

plt.show()

在这里插入图片描述

案例2-----横着的条形图(matplotlib)
'''
横着的条形图:plt.barh(x,y,height=0.2)
假如你获取到了2017年内地电影票房前20的电影(列表a)和电影票房数据(列表b),那么如何更加直观的展示该数据?
a = ["战狼2","速度与激情8","功夫瑜伽","西游伏妖篇","变形金刚5:最后的骑士","摔跤吧!爸爸","加勒比海盗5:死无对证","金刚:骷髅岛","极限特工:终极回归","生化危机6:终章","乘风破浪","神偷奶爸3","智取威虎山","大闹天竺","金刚狼3:殊死一战","蜘蛛侠:英雄归来","悟空传","银河护卫队2","情圣","新木乃伊",]
b =[56.01,26.94,17.53,16.49,15.45,12.96,11.8,11.61,11.28,11.12,10.49,10.3,8.75,7.55,7.32,6.99,6.88,6.86,6.58,6.23]
'''
from matplotlib import pyplot as plt
from matplotlib import font_manager
my_font = font_manager.FontProperties(fname='c:/Windows/Fonts/FZSTK.TTF')

x = ["战狼2","速度与激情8","功夫瑜伽","西游伏妖篇","变形金刚5:最后的骑士","摔跤吧!爸爸","加勒比海盗5:死无对证","金刚:骷髅岛","极限特工:终极回归","生化危机6:终章","乘风破浪","神偷奶爸3","智取威虎山","大闹天竺","金刚狼3:殊死一战","蜘蛛侠:英雄归来","悟空传","银河护卫队2","情圣","新木乃伊",]
y =[56.01,26.94,17.53,16.49,15.45,12.96,11.8,11.61,11.28,11.12,10.49,10.3,8.75,7.55,7.32,6.99,6.88,6.86,6.58,6.23]
plt.figure(figsize=(20,8),dpi=80)

# 绘制横着的条形图
plt.barh(range(len(x)), y, height=0.3)

# 设置y轴的刻度
_x = range(len(x))
_xtick_labels = x
plt.yticks(_x, _xtick_labels,fontproperties=my_font)

plt.show()

在这里插入图片描述

案例3-----多级的条形图(matplotlib)
'''
绘制条形图:
      plt.bar(x,y,width=0.2)     # 绘制竖着的条形图
      plt.barh(x,y,height=0.2)    # 绘制横着的条形图
题目:假设你知道了列表a中电影分别在2017-09-14(b_14),2017-09-15(b_15),2017-09-16(b_16)三天的票房,
      为了展示列表中电影本身的票房以及同其他电影的数据对比情况,应该如何更加直观的呈现该数据?
      a = ["猩球崛起3:终极之战","敦刻尔克","蜘蛛侠:英雄归来","战狼2"]
      b_14 = [2358,399,2358,362] 
      b_15 = [12357,156,2045,168]      
      b_16 = [15746,312,4497,319]
'''
from matplotlib import pyplot as plt
from matplotlib import font_manager
my_font = font_manager.FontProperties(fname='C:\\Windows\\Fonts\\FZSTK.TTF')

x = ["猩球崛起3:终极之战","敦刻尔克","蜘蛛侠:英雄归来","战狼2"]     # 4
y_14 = [2358,399,2358,362]      # 4
y_15 = [12357,156,2045,168]     # 4
y_16 = [15746,312,4497,319]     # 4
plt.figure(figsize=(20,8),dpi=80)

# 绘制多级条形图
bar_width = 0.2
x_14 = list(range(len(x)))              # range(4) 等价于 range(0,4) 等价于 [0,1,2,3]
x_15 = [i+bar_width for i in x_14]     # [0.2, 1.2, 2.2, 3.2]
x_16 = [i+bar_width*2 for i in x_14]   # [0.4, 1.4, 2.4, 3.4]
plt.bar(x_14,y_14,width=bar_width,label='9月14日')
plt.bar(x_15,y_15,width=bar_width,label='9月15日')
plt.bar(x_16,y_16,width=bar_width,label='9月16日')

# 设置x轴的刻度
_x = x_15           # x_15:刻度放在中间
_xtick_labels = x
plt.xticks(_x,_xtick_labels,fontproperties=my_font)

# 设置图例
plt.legend(prop=my_font,loc='upper right')

plt.show()

在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值