当前位置:   article > 正文

使用Python制作简单的图表并设置图表元素_在matplotlib.pyplot模块中使用函数_________可设置图表的标题。

在matplotlib.pyplot模块中使用函数_________可设置图表的标题。

案例01 在python中制作简单的图表

  1. import matplotlib.pyplot as plt # 导入matplotlib模块
  2. x = [1, 2, 3, 4, 5, 6] # 给出x坐标的数据
  3. y = [2, 4, 6, 8, 10, 12] # 给出y坐标的数据
  4. plt.plot(x, y, color = 'red', linewidth = 3, linestyle = 'solid') # 绘制折线图
  5. plt.show() # 显示绘制的图表

运行结果:

 

知识延伸

1、plot()是Matplotlib模块的函数,用于绘制折线图

语法格式:

plot(x,y,color,linewidth,linestyle)

参数说明
xx坐标的值
yy坐标的值
color

折线的颜色。Matplotlib模块支持多种格式定义的颜色,常用的有

  • 用颜色的单词或其简写定义的8种基础颜色
  • 用RGB值的浮点数元组定义的颜色,RGB值通常是用0~255的十进制整数表示的
  • 用RGB值的十六进制字符串定义的颜色,如‘#33FF00’,其与(51,255,0)是相同的RGB颜色,可以搜索“十六进制颜色码转换工具”来获取更多颜色
linewidth折线的粗细
linestyle折线的类型。用特定含义的字符串表示,如:实线用‘-’或‘solid’表示

 2、show()是Matplotlib模块的函数,用于显示绘制的图表。

在python中绘制柱形图

  1. import matplotlib.pyplot as plt
  2. x = [1, 2, 3, 4, 5, 6]
  3. y = [50, 60, 80, 78, 95, 70]
  4. plt.bar(x, y, width = 0.8, align = 'center', color = 'blue') # 绘制柱形图
  5. plt.show()

运行结果:

 

bar()就是Matplotlib模块中用于制作柱形图的函数。

语法格式:

bar(x,height,width=0.8,bottom=None,align='center',color,edgecolor,linewidth)

参数说明
xx坐标的值
heighty坐标的值,也就是每根柱子的高度
width柱子的宽度,默认值为0.8
bottom每根柱子的底部的y坐标值
align柱子的位置与x坐标的关系。默认值为‘center’,表示柱子与x坐标居中对齐;如为‘edge’,表示柱子与x坐标左对齐
color柱子的填充颜色
edgecolor柱子的边框颜色
linewidth柱子的边框粗细

在python中绘制条形图

  1. import matplotlib.pyplot as plt
  2. x = [1, 2, 3, 4]
  3. y = [60, 25, 78, 50]
  4. plt.barh(x, y, align = 'center', color = 'blue') # 绘制条形图
  5. plt.show()

运行结果:

 

barh()就是Matplotlib模块中用于绘制条形图的函数。

语法格式:

barh(y,width,height=0.8,left=None,align='center',color,edgecolor,linewidth)

参数说明
yy坐标的值
widthx坐标的值,也就是每根条形的宽度
height条形的高度,默认值为0.8
left每根条形的左侧边缘的x坐标值
align

条形的位置与y坐标的关系。默认值为‘center’,表示条形与y坐标居中对齐;如为‘edge’,表示条形的底部与y坐标对齐

color条形的填充颜色
edgecolor条形的边框颜色
linewidth条形的边框粗细

在python中制作饼图

  1. import matplotlib.pyplot as plt
  2. x = [25, 45, 69, 30, 80, 12]
  3. plt.pie(x) # 根据x坐标值绘制饼图
  4. plt.show()

运行结果:

 

案例02 在python中导入Excel数据制作简单的图表——销售业绩表.xlsx

导入数据制作柱形图

  1. import pandas as pd
  2. import matplotlib.pyplot as plt
  3. import xlwings as xw
  4. df = pd.read_excel('销售业绩表.xlsx') # 从指定工作簿中读取数据
  5. figure = plt.figure() # 创建一个绘图窗口
  6. plt.rcParams['font.sans-serif'] = ['SimHei'] # 为图表中的中文文本设置默认字体,以避免中文显示乱码问题
  7. plt.rcParams['axes.unicode_minus'] = False # 解决坐标值为负数时无法正常显示负号的问题
  8. x = df['月份'] # 指定“月份”列为x坐标的值
  9. y = df['销售额'] # 指定“销售额”列为y坐标的值
  10. plt.bar(x, y, color = 'black') # 制作柱形图
  11. app = xw.App(visible = False) # 启动Excel程序
  12. workbook = app.books.open('销售业绩表.xlsx') # 打开要插入图表的工作簿
  13. worksheet = workbook.sheets['销售业绩'] # 选中要插入图表的工作表
  14. worksheet.pictures.add(figure, left = 500) # 在工作表中插入柱形图
  15. workbook.save()
  16. workbook.close()
  17. app.quit()

运行结果:

知识延伸

SimHei是黑体的英文名称,如果想使用其他字体,可参考如下的常用字体名称中英文对照表

字体中文名称字体英文名称字体中文名称字体英文名称
黑体SimHei仿宋FangSong
微软雅黑Microsoft YaHei楷体KaiTi
宋体SimSun细明体MingLiU
新宋体NSimSun新细明体PMingLiU
 

导入数据制作散点图

  1. import pandas as pd
  2. import matplotlib.pyplot as plt
  3. import xlwings as xw
  4. df = pd.read_excel('销售业绩表.xlsx')
  5. figure = plt.figure()
  6. plt.rcParams['font.sans-serif'] = ['SimHei']
  7. plt.rcParams['axes.unicode_minus'] = False
  8. x = df['月份']
  9. y = df['销售额']
  10. plt.scatter(x, y, s = 500, color = 'red', marker = '*') # 制作散点图
  11. app = xw.App(visible = False)
  12. workbook = app.books.open('销售业绩表.xlsx')
  13. worksheet = workbook.sheets['销售业绩']
  14. worksheet.pictures.add(figure, left = 500)
  15. workbook.save()
  16. workbook.close()
  17. app.quit()

运行结果:

 

scatter()是Matplotlib模块中用于制作散点图的函数,参数marker用于设置散点图中每个点的形状。 

导入数据制作面积图

  1. import pandas as pd
  2. import matplotlib.pyplot as plt
  3. import xlwings as xw
  4. df = pd.read_excel('销售业绩表.xlsx')
  5. figure = plt.figure()
  6. plt.rcParams['font.sans-serif'] = ['SimHei']
  7. plt.rcParams['axes.unicode_minus'] = False
  8. x = df['月份']
  9. y = df['销售额']
  10. plt.stackplot(x, y, colors = 'red') # 制作面积图
  11. app = xw.App(visible = False)
  12. workbook = app.books.open('销售业绩表.xlsx')
  13. worksheet = workbook.sheets['销售业绩']
  14. worksheet.pictures.add(figure, left = 500)
  15. workbook.save()
  16. workbook.close()
  17. app.quit()

运行结果:

 

stackplot()是Matplotlib模块中用于制作面积图的函数。

语法格式:

stackplot(x,y,labels,colors)

参数说明
xx坐标的值
yy坐标的值
labels图表的图例名
colors图表的颜色

案例03 在python中制作组合图表——销售业绩表1.xlsx

  1. import pandas as pd
  2. import matplotlib.pyplot as plt
  3. df = pd.read_excel('销售业绩表1.xlsx')
  4. plt.rcParams['font.sans-serif'] = ['SimHei']
  5. plt.rcParams['axes.unicode_minus'] = False
  6. x = df['月份'] # 指定数据中的“月份”列为x坐标的值
  7. y1 = df['销售额'] # 指定数据中的“销售额”列为y坐标的第1组值
  8. y2 = df['利润'] # 指定数据中的“利润”列为y坐标的第2组值
  9. plt.plot(x, y1, color = 'black', linewidth = 4) # 用x坐标和第1组y坐标制作折线图
  10. plt.bar(x, y2, color = 'blue') # 用x坐标和第2组y坐标制作柱形图
  11. plt.show()

运行结果:

 

 知识延伸

组合图表的制作和单个图表的制作方法基本相同,区别在于单个图表中的x和y坐标的值都只有一组,而组合图表的x坐标的值可能会被两组y坐标的值共用,或者y坐标的值会被两组x坐标的值共用。在制作组合图表时,只需要为图表设置两组x坐标值或两组y坐标值,然后制作两个图表即可。

制作双折线图

  1. import pandas as pd
  2. import matplotlib.pyplot as plt
  3. df = pd.read_excel('销售业绩表1.xlsx')
  4. plt.rcParams['font.sans-serif'] = ['SimHei']
  5. plt.rcParams['axes.unicode_minus'] = False
  6. x1 = df['月份']
  7. y1 = df['销售额']
  8. y2 = df['利润']
  9. plt.plot(x1, y1, color = 'red', linewidth = 3, linestyle = 'solid')
  10. plt.plot(x1, y2, color = 'black', linewidth = 3, linestyle = 'solid')
  11. plt.show()

运行结果:

 

案例04 添加并设置图表标题和坐标轴标题——销售业绩表.xlsx

  1. import pandas as pd
  2. import matplotlib.pyplot as plt
  3. df = pd.read_excel('销售业绩表.xlsx')
  4. plt.rcParams['font.sans-serif'] = ['SimHei']
  5. plt.rcParams['axes.unicode_minus'] = False
  6. x = df['月份'] # 指定数据中的“月份”列为x坐标的值
  7. y = df['销售额'] # 指定数据中的”销售额“列为y坐标的值
  8. plt.bar(x, y, color = 'black') # 制作柱形图
  9. plt.title(label = '各月销售额对比图', fontdict = {'family' : 'KaiTi', 'color' : 'red', 'size' : 20}, loc = 'left') # 添加并设置图表标题
  10. plt.xlabel('月份', fontdict = {'family' : 'SimSun', 'color' : 'black', 'size' : 15}, labelpad = 10) # 添加并设置x轴标题
  11. plt.ylabel('销售额', fontdict = {'family' : 'SimSun', 'color' : 'black', 'size' : 15}, labelpad = 10) # 添加并设置y轴标题
  12. plt.show()

运行结果:

 

知识延伸

1、title()是Matplotlib模块中的函数,用于给图表添加和设置标题。

语法格式:

title(label,fontdict=None,loc='center',pad=None)

参数说明
label图表标题的文本内容
fontdict图表标题的字体、字号和颜色等
loc图表标题的显示位置。默认值为‘center’,表示在图表上方居中显示。还可以设置为‘left’或‘right’,表示在图表上方靠左或靠右显示
pad图表标题到图表坐标系顶端的距离

 2、xlabel()和ylabel()是Matplotlib模块中的函数,分别用于添加和设置x、y轴的标题。

语法格式:

xlabel/ylabel(label,fontdict=None,labelpad=None)

参数说明
label坐标轴标题的文本内容
fontdict坐标轴标题的字体、字号和颜色等
labelpad坐标轴标题到坐标轴的距离

添加图例

  1. import pandas as pd
  2. import matplotlib.pyplot as plt
  3. df = pd.read_excel('销售业绩表.xlsx')
  4. plt.rcParams['font.sans-serif'] = ['SimHei']
  5. plt.rcParams['axes.unicode_minus'] = False
  6. x = df['月份']
  7. y = df['销售额']
  8. plt.bar(x, y, color = 'red', label = '销售额') # 制作柱形图并设置图例名
  9. plt.legend(loc = 'upper left', fontsize = 20) # 添加并设置图例
  10. plt.show()

运行结果:

 legend()是Matplotlib模块中的函数,用于为图表添加并设置图例。

语法格式:

legend(loc,fontsize,facecolor,edgecolor,shadow=False)

参数说明
loc图例的显示位置。取值为特定的字符串,常用的有‘upper left’、‘upper right’、‘lower left’、‘lower right’,分别表示左上角、右上角、左下角、右下角
fontsize图例名的字号
facecolor图例框的背景颜色
edgecolor图例框的边框颜色
shadow是否给图例框添加阴影,默认值为False,表示不添加阴影

案例05 添加并设置数据标签——销售业绩表.xlsx

  1. import pandas as pd
  2. import matplotlib.pyplot as plt
  3. df = pd.read_excel('销售业绩表.xlsx')
  4. plt.rcParams['font.sans-serif'] = ['SimHei']
  5. plt.rcParams['axes.unicode_minus'] = False
  6. x = df['月份']
  7. y = df['销售额']
  8. plt.plot(x, y, color = 'red', linewidth = 3, linestyle = 'solid') # 制作折线图
  9. for a,b in zip(x, y):
  10. plt.text(a, b, b, fontdict = {'family' : 'KaiTi', 'color' : 'red', 'size': 20}) # 添加并设置数据标签
  11. plt.show()

运行结果:

知识延伸

1、zip()是python的内置函数,它以可迭代的对象作为参数,将对象中对应的元素打包成一个元组,然后返回由这些元组组成的列表。

语法格式:

zip([iterable,…])

iterable:指一个或多个可迭代的对象

2、text()是Matplotlib模块中的函数,用于为图标添加并设置数据标签。

语法格式:

text(x,y,s,fontdict=None)

参数说明
x数据标签的x坐标
y数据标签的y坐标
s数据标签的文本内容
fontdict可选参数,用于设置数据标签的字体、字号、颜色等
 

设置y轴的取值范围

  1. import pandas as pd
  2. import matplotlib.pyplot as plt
  3. df = pd.read_excel('销售业绩表.xlsx')
  4. plt.rcParams['font.sans-serif'] = ['SimHei']
  5. plt.rcParams['axes.unicode_minus'] = False
  6. x = df['月份']
  7. y = df['销售额']
  8. plt.plot(x, y, color = 'red', linewidth = 3, linestyle = 'solid')
  9. plt.ylim(0, 1200000) # 设置y轴的取值范围
  10. for a,b in zip(x, y):
  11. plt.text(a, b, b, fontdict = {'family' : 'KaiTi', 'color' : 'red', 'size': 20})
  12. plt.show()

运行结果:

 ylim()是Matplotlib模块中用于为图表设置y轴取值范围的函数。

语法格式:

ylim(num1,num2)

参数:

num1:y轴的最小值

num2:y轴的最大值

案例06 为组合图表添加并设置次坐标——销售业绩表2.xlsx

  1. import pandas as pd
  2. import matplotlib.pyplot as plt
  3. df = pd.read_excel('销售业绩表2.xlsx')
  4. plt.rcParams['font.sans-serif'] = ['SimHei']
  5. plt.rcParams['axes.unicode_minus'] = False
  6. x = df['月份'] # 指定数据中的”月份“列为坐标的值
  7. y1 = df['销售额'] # 指定数据中的”销售额“列为y坐标的第1组值
  8. y2 = df['同比增长'] # 指定数据中的”同比增长“列为y坐标的第2组值
  9. plt.bar(x, y1, color = 'grey', label = '销售额') # 制作柱形图
  10. plt.legend(loc = 'upper left', fontsize = 20) # 为柱形图添加和设置图例
  11. plt.twinx() # 为图表设置双坐标轴
  12. plt.plot(x, y2, color = 'black', linewidth = 3, label = '同比增长') # 制作折线图
  13. plt.legend(loc = 'upper right', fontsize = 20) # 为折线图添加和设置图例
  14. plt.show()

运行结果:

twinx()是Matplotlib模块中的函数,用于为图表设置双坐标轴。该函数没有参数,可直接使用。 

添加并设置网格线——销售业绩表.xlsx

  1. import pandas as pd
  2. import matplotlib.pyplot as plt
  3. df = pd.read_excel('销售业绩表.xlsx')
  4. plt.rcParams['font.sans-serif'] = ['SimHei']
  5. plt.rcParams['axes.unicode_minus'] = False
  6. x = df['月份']
  7. y = df['销售额']
  8. plt.plot(x, y, color = 'black', linewidth = 3, linestyle = 'solid')
  9. plt.grid(b = True, axis = 'y', color = 'red', linestyle = 'dashed', linewidth = 1) # 为y轴添加并设置网格线
  10. plt.show()

运行结果:

 grid()是Matplotlib模块中的函数,用于为图表添加并设置网格线。

语法格式:

grid(b,which,axis,color,linestyle,linewidth)

参数说明
b如果为True,表示显示网格线;如果为False,表示不显示网格线
which要设置哪种类型的网格线。取值为‘major’、‘minor’、‘both’,分别表示只设置主要网格线、只设置次要网格线、两者都设置
axis要设置哪个轴的网格线。取值为‘x‘,’y‘,’both',分别表示只设置x轴的网格线、只设置y轴的网格线、两者都设置
color网格线的颜色
linestyle网格线的线型
linewidth网格线的粗细

使用Python制作简单的图表并设置图表元素,这些案例中使用到的数据文件请点击这里 【免费】使用Python制作简单的图表并设置图表元素所用到的数据.zip资源-CSDN文库

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/知新_RL/article/detail/264860?site
推荐阅读
相关标签
  

闽ICP备14008679号