python--matplotlib-绘图

一、matplotlib–数据可视化图表

1.了解能将数据进行可视化,更直观地呈现
2.使数据更加客观更具说服力

二、绘制折线图

示例:

from matplotlib import pyplot as plt
x=range(2,26,2)
y=[15,13,14,5,17,20,25,26,27,22,18,15]
#绘图
plt.plot(x,y)
#展示
plt.show()

结果:
在这里插入图片描述

1.设置图片大小:

#设置图片大小
plt.figure(figsize=(18,8),dpi=(80))

figsize图片大小
dpi参数像素参数可以使图片更加清晰

2. 保存图片:

#保存图片
plt.savefig("./t1.png")

./t1.png当前路径下保存一张png的图片
可以保存.svg这种矢量图格式,放大不会有锯齿

3.设置x、y轴的刻度

#设置x轴的刻度
plt.xticks(x)
plt.xticks(range(2,26,1))
#plt.xticks([::3])
#设置y轴的刻度
plt.yticks(range(min(y),max(y)+1))

例题:
一天中中午十点到十二点每分钟温度随机变化的折线图
y=[random.randint(20,35) for i in range(120)](随机数)
答:
设置x、y轴刻度

#设置x、y轴
_xtick_labels=["10点{}分".format(i) for i in range(60)]
_xtick_labels+=["11点{}分".format(i) for i in range(60)]
plt.yticks(y)
#取步长,数字和字符串一一对应,数据的长度一样
plt.xticks(list(x)[::3],_xtick_labels[::3],rotation=45) #rotation= 旋转角度

已经出现每个小时每分钟,但是中文不显示
已经出现每个小时每分钟,但是中文不显示。

4.设置坐标中文字体

**第一种方法:**直接另外加一行代码 plt.xticks(fontproperties=“STSong”)
Windows系统直接能显示中文!!!
在这里插入图片描述
第二种方法:

from matplotlib import font_manager
my_font = font_manager.FontProperties(fname=r"c:\windows\fonts\msyh.ttc")
#设置x,y轴相关信息,设置主题
plt.xlabel("时间",fontproperties=my_font)
plt.ylabel("温度 单位(℃)",fontproperties=my_font)
plt.title("十点到十二点每分钟气温变化折线图",fontproperties=my_font)

5.添加x、y轴相关信息

#设置x,y轴相关信息,设置主题
plt.xlabel("时间",fontproperties="STSong")
plt.ylabel("温度 单位(℃)",fontproperties="STSong")
plt.title("十点到十二点每分钟气温变化折线图",fontproperties="STSong")

后面的**fontproperties=“STSong”**使得坐标和主题信息显示中文
完整代码:

from matplotlib import pyplot as plt
import random

#设置x,y轴坐标参数
x=range(0,120)
y=[random.randint(20,35) for i in range(120)]

#设置图片大小
plt.figure(figsize=(18,8),dpi=80)

#设置x的刻度
#plt.xticks(range(0,120,5))
#设置y的刻度
#plt.yticks(range(min(y),max(y),1))

#设置x、y轴
_xtick_labels=["10点{}分".format(i) for i in range(60)]
_xtick_labels+=["11点{}分".format(i) for i in range(60)]
#取步长,数字和字符串一一对应,数据的长度一样
plt.xticks(list(x)[::3],_xtick_labels[::3],rotation=45) #rotation= 旋转角度
plt.yticks(y)

#显示中文
plt.xticks(fontproperties="STSong")

#设置x,y轴相关信息,设置主题
plt.xlabel("时间",fontproperties="STSong")
plt.ylabel("温度 单位(℃)",fontproperties="STSong")
plt.title("十点到十二点每分钟气温变化折线图",fontproperties="STSong")


#绘图
plt.plot(x,y)
#展示
plt.show()

或者:

from matplotlib import pyplot as plt
import random
from matplotlib import font_manager

#设置x,y轴坐标参数
x=range(0,120)
y=[random.randint(20,35) for i in range(120)]

#设置图片大小
plt.figure(figsize=(18,8),dpi=80)

#设置x的刻度
#plt.xticks(range(0,120,5))
#设置y的刻度
#plt.yticks(range(min(y),max(y),1))

#设置x、y轴
_xtick_labels=["10点{}分".format(i) for i in range(60)]
_xtick_labels+=["11点{}分".format(i) for i in range(60)]
#取步长,数字和字符串一一对应,数据的长度一样
plt.xticks(list(x)[::3],_xtick_labels[::3],rotation=45) #rotation= 旋转角度
plt.yticks(y)

#显示中文
#plt.xticks(fontproperties="STSong")
my_font = font_manager.FontProperties(fname=r"c:\windows\fonts\msyh.ttc")

#设置x,y轴相关信息,设置主题
plt.xlabel("时间",fontproperties=my_font)
plt.ylabel("温度 单位(℃)",fontproperties=my_font)
plt.title("十点到十二点每分钟气温变化折线图",fontproperties=my_font)


#绘图
plt.plot(x,y)
#展示
plt.show()

6.绘制网格

plt.grid(alpha=0.1)  #alpha透明度

linestyle=‘ ’#添加形状
在这里插入图片描述

7.绘制图例

在这里插入图片描述

#绘图
plt.plot(x,y1,label="自己")
plt.plot(x,y2,label="同桌")  #第一步:添加label参数
#添加图例
plt.legend(prop="STSong",loc=0) #第二部:添加图例(第一种显示中文的方式)
 #prop显示中文,loc确定图例出现在哪一个位置
#plt.legend(prop=my_font,loc=0)#第二种显示中文的方式

8.自定义绘制图线的风格

在这里插入图片描述

9.总结:

在这里插入图片描述

三、绘制散点图

绘制散点图与绘制折线图相似,
主要区别:折线图plt.plot() 散点图plt.scatter()

举例:

在这里插入图片描述

from matplotlib import pyplot as plt
from matplotlib import font_manager

#中文显示
my_font = font_manager.FontProperties(fname=r"c:\windows\fonts\msyh.ttc")

y3=[1,2,3,16,15,54,32,12,32,34,21,32,45,12,32,24,2,6,9,20,32,26,28,32,26,12,23,24,18,19,12]
y4=[12,13,15,16,18,19,17,25,26,23,24,20,21,5,9,8,7,6,20,23,26,24,28,32,35,31,20,29,24,32,21]

x3=range(1,32)
x4=range(51,82)

#设置图片大小
plt.figure(figsize=(18,8),dpi=80)

#与折线图区别地方,scatter
plt.scatter(x3,y3,label="三月份")
plt.scatter(x4,y4,label="十月份")

#设置x,y轴
_x=list(x3)+list(x4)
_xtick_labels=["三月{}日".format(i) for i in x3]
_xtick_labels+=["十月{}日".format(i-50) for i in x4]
plt.xticks(_x[::3],_xtick_labels[::3],fontproperties=my_font,rotation=45)

#添加信息
plt.xlabel("日期",fontproperties=my_font,size=20)
plt.ylabel("温度",fontproperties=my_font,size=20)
plt.title("标题",fontproperties=my_font,size=20)

#添加图例
plt.legend(prop=my_font,loc=2)

#展示
plt.show()

四、绘制条形图

1.绘制纵向条形图:plt.bar()

在这里插入图片描述

2.绘制横向条形图:plt.barh()

在这里插入图片描述

3.例子:

在这里插入图片描述
代码:

from matplotlib import pyplot as plt
from matplotlib import font_manager

#显示中文
my_font = font_manager.FontProperties(fname=r"c:\windows\fonts\msyh.ttc")

a=["猩球崛起3:终极之战","敦刻尔克","蜘蛛侠:英雄归来","战狼2"]
b_16=[15746,312,4497,319]
b_15=[12357,156,2045,168]
b_14=[2358,399,2358,362]

#设置图片大小
plt.figure(figsize=(18,8),dpi=80)

#使三个日期的图形不会重叠
bar_width=0.2  #向右的距离
x_14=list(range(len(a)))
x_15=[i+bar_width for i in x_14]
x_16=[i+bar_width*2 for i in x_14]

#绘制条形图
plt.bar(x_14,b_16,width=0.2,label="2017-09-16")
plt.bar(x_15,b_15,width=0.2,label="2017-09-15")
plt.bar(x_16,b_14,width=0.2,label="2017-09-14")

#设置x,y轴
plt.xticks(x_15,a,fontproperties=my_font)

#添加相关信息
plt.xlabel("电影",fontproperties=my_font)
plt.ylabel("票房 单位(亿)",fontproperties=my_font)
plt.title("在三天里三部电影的票房",fontproperties=my_font)

#添加图例
plt.legend(prop=my_font,loc=0)

#展示
plt.show()

结果;
在这里插入图片描述

五、绘制直方图

绘制直方图:plt.hist(a,num_bins(分的组数))

例子:

在这里插入图片描述
计算组数

#计算组数
d=5 #组距
num_bins=(max(a)-min(a))//d
from matplotlib import pyplot as plt
from matplotlib import font_manager

#设置x,y轴数值
a=[131,98,125,131,124,139,131,117,128,108,135,138,131,102,107,114, 119,128,121,142,127,130,124,101,110.116,117,110,128,128,115,99,136,126,134,95,138,117,111,78,132,124,113,150,110,117,86,95,144,105, 126,130,126,130,126,116,123,106,112,138,123,86,101,99,136,123,17,119,105,137,123,128,125,104,109,34,125,127,105, 120, 107,129, 116,108,132,103, 136, 118,102,120,14,105,115,132,45,119,121.112,139,125,138,109,132,134,156,106,117,127, 144,139,139,19,140,83,110,102,123,107, 143, 115,136,118,139,123,112, 118, 125, 109,119,133,112,114,122,109,106,123,116, 131,127,115,118,112,135,115,146,137,116, 103,144,83,123,111, 110,11,100,154,136, 100,118, 119,133,134,106,129,126,110, 111,109,141,120,117,106,149,122,122, 110, 118, 127,121,114,125,126,114, 140, 103,130,141, 117, 106,14,121,114,133,137,92,121,112,146,97,137,105,98,117,112,81,97,139,113,134,106,144, 110,137,137, 111, 104, 117,100,11,101,110,105,129,137,112, 120,13,133,112,83,94,146,133,101,131,116.111,84,137,115,122,106,144,109,123,116,111,111,133,150]

#计算组数
d=5 #组距
num_bins=(max(a)-min(a))//d  #能被整除 组数

#设置图片大小
plt.figure(figsize=(18,8),dpi=80)

#绘制直方图
plt.hist(a,num_bins,density=True)#density为属性

#设置x轴刻度
plt.xticks(range(min(a),max(a)+d,d))

#绘制网格
plt.grid(alpha=0.5)

#展示
plt.show()

在这里插入图片描述
在这里插入图片描述

  • 0
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值