analysis专栏 02.数据可视化模块 05.绘制柱状图

# 05.绘制柱状图

[toc]{type: "ol", level: [3,4,5]}

### 柱状图
```python
import matplotlib.pyplot as plt
x = [1980, 1985, 1990, 1995]
x_label = ['1980年','1985年','1990年','1995年']
y = [1000, 3000, 4000, 5000]
plt.bar(x, y, width=3)
plt.rcParams['font.sans-serif'] = ['Heiti TC']
plt.xticks(x, x_label)
plt.xlabel('年份')
plt.ylabel('销量')
plt.title('1980-1995 年份销量对比图')
```
![柱状图](imgs/11.png)


### 分割画布
```python
import matplotlib.pyplot as plt
import numpy as np
np.random.seed(0)
x = np.arange(6)
y = np.random.randint(-6, 6, 6)

# 将画布分割成1行2列 在第1列中画图
plt.subplot(1, 2, 1)
v_bar = plt.bar(x, y, color='green')
# 添加水平线
plt.axhline(0, color='blue', linewidth=2)

# 将画布分割成1行2列 在第2列中画图
plt.subplot(1, 2, 2)
h_bar = plt.barh(x, y, color='gold')
# 添加竖直线
plt.axvline(0, color='brown', linewidth=2)
plt.show()
```
![柱状图](imgs/12.png)
::: danger
barh没有width参数
:::


### 影票案例
```python
import matplotlib.pyplot as plt
import numpy as np
# 设置基本参数
real_names = ['千与千寻', '玩具总动员', '黑衣人']
real_num1 = [5453, 7548, 6543]
real_num2 = [1840, 4013, 3421]
real_num3 = [1080, 1673, 2342]
x = np.arange(1, 4)
# [1, 2, 3]
x_label = ['第{}天'.format(i) for i in x]
# ['第1天', '第2天', '第3天']
width = 0.3

# 电影1
plt.bar(x, real_num1, color='gold', width=width, label=real_names[0])
# 电影2
# 将x中每个元素+一个宽度 [i+width for i in x]
plt.bar([i+width for i in x], real_num2, color='green', width=width, label=real_names[1])
# 电影3
plt.bar([i+width*2 for i in x], real_num3, color='blue', width=width, label=real_names[2])

# 设置中文字体
plt.rcParams['font.sans-serif'] = ['Heiti TC']
# 修改x坐标
plt.xticks([i+width for i in x], x_label)
# 添加图例
plt.legend()
# 添加标题
plt.title('3日内影院票房数')
```
![柱状图](imgs/13.png)

 

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值