脚本之家,脚本语言编程技术及教程分享平台!
分类导航

Python|VBS|Ruby|Lua|perl|VBA|Golang|PowerShell|Erlang|autoit|Dos|bat|

服务器之家 - 脚本之家 - Python - Python绘制组合图的示例

Python绘制组合图的示例

2020-09-18 00:08爽歪歪666 Python

这篇文章主要介绍了Python如何绘制组合图,帮助大家更好的利用python绘制图像,进行数据可视化分析,感兴趣的朋友可以了解下

绘制组合图:

组合图就是将多个形状,组合到⼀个图形中,主要作⽤是节约作图的空间,节省读者的时间,从⽽提⾼
信息传达的效率。

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
import pandas as pd
import numpy as np
import matplotlib.pyplot as plt
def plot_combination1():
  sale = pd.read_excel('./data/每月目标销售额和实际销售额.xlsx',header=0,index_col=0)
  # 设置正常显示中文标签
  plt.rcParams['font.sans-serif'] = ['SimHei']
  # 正常显示负号
  plt.rcParams['axes.unicode_minus'] = False
  # 设置字体大小
  plt.rcParams.update({'font.size':16})
 
  # 提取数据
  x = np.arange(12)+1
  y1 = sale.目标销售额
  y2 = sale.实际销售额
 
  # 计算目标完成率
  y3 = y2/y1 # float
  # print(y3) 1月   1.120000 2月   0.887500 3月   1.118182 4月   1.150000
  """
  第一种方式:是⽤两个不同颜⾊的柱⼦,分别展示每个⽉的实际销售额和⽬标销售额,
  ⽤折线图展示⽬标完成率。
  左边的主坐标轴是柱形图对应的数据,右边的次坐标轴是折线图对应的
  数据,下边的横坐标轴表示细分的维度,⽐如时间、地区、渠道等。
  """
  plt.figure(figsize=(16,8))
  plt.subplot(111)
 
  # 柱形宽度
  bar_width = 0.35
 
  # 在主坐标轴绘制柱形图
  plt.bar(x,y1,bar_width,label='目标销售额')
  plt.bar(x+bar_width,y2,bar_width,label='实际销售额')
 
  # 设置坐标轴的取值范围,避免柱子过高而与图例重叠
  plt.ylim(0,max(y1.max(),y2.max())*1.2)
 
  # 设置图例
  plt.legend(loc='upper left')
 
  # 设置横坐标的标签
  plt.xticks(x)
  # plt.set_xticklabels(sale.index)
 
  # 在次坐标轴上绘制折线图
  plt.twinx()
  # ls:线的类型,lw:宽度,o:在顶点处实心圈
  plt.plot(x,y3,ls='-',lw=2,color='r',marker='o',label='目标完成率')
 
  # 设置次坐标轴的取值范围,避免折线图波动过大
  plt.ylim(0,1.35)
 
  # 设置图例
  plt.legend()
 
  # 定义显示百分号的函数
  def to_percent(number, position=0):
    return '%.f' % (number * 100) + '%'
 
  # 次坐标轴的标签显示百分号 FuncFormatter:自定义格式函数包
  from matplotlib.ticker import FuncFormatter
  plt.gca().yaxis.set_major_formatter(FuncFormatter(to_percent))
 
  # 设置标题
  plt.title('\n每月销售目标达成情况\n',fontsize=36,loc='center',color = 'k')
  plt.show()
 
 
 
def plot_combination2():
  """
  第二种方式:是⽤两条不同颜⾊的折线,分别展示每个⽉的实际销售额和⽬标销售额,再⽤两种不同颜
  ⾊的柱形图展示实际与⽬标的差额,绿⾊代表完成⽬标,红⾊代表没有完成⽬标,
  这种组合图不需要⽤到两个纵坐标轴,
  """
  import pandas as pd
  import numpy as np
  import matplotlib.pyplot as plt
 
  # 设置正常显示中⽂标签
  plt.rcParams['font.sans-serif'] = ['SimHei']
 
  # 正常显示负号
  plt.rcParams['axes.unicode_minus'] = False
 
  # 设置字体⼤⼩
  plt.rcParams.update({'font.size': 16})
 
  # 从 Excel ⽂件中读取数据,第⼀列设置为索引
  sale = pd.read_excel('./data/每月目标销售额和实际销售额.xlsx', index_col=0)
  # 提取数据
  # print('index')
  x = sale.index # Index(['1月', '2月', '3月', '4月', '5月', '6月', '7月', '8月', '9月', '10月', '11月', '12月'], dtype='object', name='month')
  # print(x)
  y1 = sale.目标销售额
  y2 = sale.实际销售额
  # 计算差额
  y3 = y2 - y1
  # 绘制折线图
  plt.figure(figsize=(16, 8))
  plt.subplot(111)
  plt.plot(x, y1, ls='-', lw=2, label='目标销售额')
  plt.plot(x, y2, ls='--', lw=2, label='实际销售额')
  # ⽤列表推导式定义柱⼦的颜⾊,绿⾊代表完成⽬标, 红⾊代表没有完成⽬标
  color = ['g' if i > 0 else '#dc5034' for i in y3]
 
  # 绘制柱形图
  plt.bar(x, y3, color=color, label='差额')
  # 设置图例
  plt.legend(loc='upper left')
  # 设置标题
  title = '\n每月销售目标达成情况\n'
  plt.title(title, fontsize=36, loc='center', color='k')
  plt.show()
 
if __name__ == '__main__':
  plot_combination1()
  plot_combination2()

绘制结果:

第一种 

Python绘制组合图的示例

第二种:

Python绘制组合图的示例

参考书目:

数据化分析 Python 实战 - 林骥

以上就是Python绘制组合图的示例的详细内容,更多关于Python绘制组合图的资料请关注服务器之家其它相关文章!

原文链接:https://www.cnblogs.com/shuangcao/p/13155786.html

延伸 · 阅读

精彩推荐