重庆分公司,新征程启航
为企业提供网站建设、域名注册、服务器等服务
pip install matplotlib
作为一家“创意+整合+营销”的成都网站建设机构,我们在业内良好的客户口碑。成都创新互联提供从前期的网站品牌分析策划、网站设计、成都网站制作、成都网站建设、创意表现、网页制作、系统开发以及后续网站营销运营等一系列服务,帮助企业打造创新的互联网品牌经营模式与有效的网络营销方法,创造更大的价值。
import matplotlib.pyplot as plt
import random
x=range(10) # 定义x轴的数据
y=[random.uniform(15,35) for i in x] # 定义y轴的数据
plt.plot(x, y) # 绘制图像
plt.show() # 展示图像
我们使用plt.figure()
函数来设置画布大小,其参数如下:
import matplotlib.pyplot as plt
import random
x=range(10) # 定义x轴的数据
y=[random.uniform(15,35) for i in x] # 定义y轴的数据
plt.figure(figsize=(20,8),dpi=80) # 设置画布大小与清晰度
plt.plot(x, y) # 绘制图像
plt.show() # 展示图像
plt.savefig('test.png')
# 在当前目录保存名为test.png的图片,必须在show方法前否则图片就是空白
xticks
,yticks
使用自定义刻度的函数,它有两个参数:
import matplotlib.pyplot as plt
import random
x=range(10) # 定义x轴的数据
y=[random.uniform(15,35) for i in x] # 定义y轴的数据
plt.figure(figsize=(20,8),dpi=80) # 设置画布大小与清晰度
plt.xticks(x[::2]) # 定义显示的x轴步长为2
plt.plot(x, y) # 绘制图像
plt.show() # 展示图像
matplotlib默认字体是不支持中文的需要更改,有多种方法,现在只提供一种
import matplotlib.pyplot as plt
import random
x=range(10) # 定义x轴的数据
y=[random.uniform(15,35) for i in x] # 定义y轴的数据
plt.figure(figsize=(20,8),dpi=80) # 设置画布大小与清晰度
plt.xticks(x[::2],["1月","2月","3月","4月","5月"]) # 第二个参数可以指定显示字符串,不过传入xticks的这两个参数长度要相等
plt.plot(x, y) # 绘制图像
plt.show() # 展示图像
修改matplotlib默认字体,使它支持显示中文
import matplotlib.pyplot as plt
import random
plt.rcParams['font.sans-serif']=['SimHei'] # 用来正常显示中文标签
x=range(10) # 定义x轴的数据
y=[random.uniform(15,35) for i in x] # 定义y轴的数据
plt.figure(figsize=(20,8),dpi=80) # 设置画布大小与清晰度
plt.xticks(x[::2],["1月","2月","3月","4月","5月"]) # 第二个参数可以指定显示字符串,不过传入xticks的这两个参数长度要相等
plt.plot(x, y) # 绘制图像
plt.show() # 展示图像
xlabel
、ylabel
使用修改x,y轴标签
title
可修改标题
import matplotlib.pyplot as plt
import random
plt.rcParams['font.sans-serif']=['SimHei'] # 用来正常显示中文标签
x=range(10) # 定义x轴的数据
y=[random.uniform(15,35) for i in x] # 定义y轴的数据
plt.figure(figsize=(20,8),dpi=80) # 设置画布大小与清晰度
plt.xticks(x[::2],["1月","2月","3月","4月","5月"]) # 第二个参数可以指定显示字符串,不过传入xticks的这两个参数长度要相等
plt.xlabel("时间变化") # 修改标签
plt.ylabel("温度变化")
plt.title("我是标题") # 修改标题
plt.plot(x, y) # 绘制图像
plt.show() # 展示图像
grid
方法来设置图表中的网格线
import matplotlib.pyplot as plt
import random
plt.rcParams['font.sans-serif']=['SimHei'] # 用来正常显示中文标签
x=range(60) # 定义x轴的数据
y=[random.uniform(15,18) for i in x] # 定义y轴的数据
plt.figure(figsize=(20,8),dpi=80) # 设置画布大小与清晰度
plt.plot(x, y) # 绘制图像
plt.xticks(x[::5],["{}分钟".format(i) for i in x][::5]) # 第二个参数可以指定显示字符串,不过传入xticks的这两个参数长度要相等
plt.yticks(range(0,40,5)) # 自定义y轴刻度
plt.xlabel("时间变化") # 修改标签
plt.ylabel("温度变化")
plt.title("我是标题") # 修改标题
# 增加网格显示,0.5表示透明度为50%
plt.grid(linestyle="--",alpha=0.5)
plt.show() # 展示图像
只是数据多准备一份罢了,基本什么区别
例外再添加上图例legend
,可读性更好
import matplotlib.pyplot as plt
import random
plt.rcParams['font.sans-serif']=['SimHei'] # 用来正常显示中文标签
x=range(60) # 定义x轴的数据
y_1=[random.uniform(15,18) for i in x] # 定义y轴的数据
y_2=[random.uniform(1,3) for i in x] # 定义y轴的数据
plt.figure(figsize=(20,8),dpi=80) # 设置画布大小与清晰度
plt.plot(x, y_1,label="上海") # 绘制图像
plt.plot(x, y_2,label="北京") # 绘制图像
plt.xticks(x[::5],["{}分钟".format(i) for i in x][::5]) # 第二个参数可以指定显示字符串,不过传入xticks的这两个参数长度要相等
plt.yticks(range(0,40,5)) # 自定义y轴刻度
plt.xlabel("时间变化") # 修改标签
plt.ylabel("温度变化")
plt.title("我是标题") # 修改标题
# 增加网格显示,0.5表示透明度为50%
plt.grid(linestyle="--",alpha=0.5)
plt.legend() #绘制图例
plt.show() # 展示图像
subplots
可以把整个画布分成多块
plt.rcParams['font.sans-serif']=['SimHei'] # 用来正常显示中文标签
plt.rcParams['axes.unicode_minus'] = False # 用来正常显示负号
# x,y轴的数据
x=range(60)
y_shanghai=[random.uniform(15,18) for i in x]
# 另一个城市
y_beijing=[random.uniform(1,3) for i in x]
fig, ax = plt.subplots(1,2,figsize=(20,8),dpi=80) # 把画布分成一行两列
ax[0].plot(x,y_shanghai,'b--',label='上海')
ax[1].plot(x,y_beijing,'r',label='北京')
# 图例,必须在plot后面
ax[0].legend()
ax[1].legend()
# 修改x y刻度
x_label=["11点{}分".format(i) for i in range(60)]
ax[0].set_xticks(x[::5],x_label[::5])
ax[1].set_xticks(x[::5],x_label[::5])
ax[0].set_yticks(range(0,40,5))
ax[1].set_yticks(range(0,40,5))
# 增加网格显示
ax[0].grid(linestyle="--",alpha=0.5)
ax[1].grid(linestyle="--",alpha=0.5)
# 添加描述信息
ax[0].set_xlabel('时间变化')
ax[0].set_ylabel('温度变化')
ax[0].set_title('上海城市11点到12点每分钟的温度变化状况')
ax[1].set_xlabel('时间变化')
ax[1].set_ylabel('温度变化')
ax[1].set_title('北京城市11点到12点每分钟的温度变化状况')
plt.show()
import matplotlib.pyplot as plt
import numpy as np;
x=np.linspace(-10,10,)
y=x**2
plt.figure(figsize=(8,8),dpi=80)
plt.grid(linestyle='--',alpha=0.5)
plt.plot(x,x**2)
plt.show()
在前面的例子中感觉显示的字体太小了,看的不舒服,现在来设置一下。
通过plt.rcParams['font.size']=18
来指定字体的大小
import matplotlib.pyplot as plt
import random
plt.rcParams['font.sans-serif']=['SimHei'] # 用来正常显示中文标签
plt.rcParams['font.size']=18 # 设置字体大小
x=range(60) # 定义x轴的数据
y=[random.uniform(15,18) for i in x] # 定义y轴的数据
plt.figure(figsize=(20,8),dpi=80) # 设置画布大小与清晰度
plt.plot(x, y) # 绘制图像
plt.xticks(x[::5],["{}分钟".format(i) for i in x][::5]) # 第二个参数可以指定显示字符串,不过传入xticks的这两个参数长度要相等
plt.yticks(range(0,40,5)) # 自定义y轴刻度
plt.xlabel("时间变化") # 修改标签
plt.ylabel("温度变化")
plt.title("我是标题") # 修改标题
# 增加网格显示,0.5表示透明度为50%
plt.grid(linestyle="--",alpha=0.5)
plt.show() # 展示图像
主要使用scatter
方法来绘制散点图,参数如下:
参数说明:
import matplotlib.pyplot as plt
import numpy as np
plt.rcParams['font.size'] = 18
x = np.array([1, 2, 3, 4, 5, 6, 7, 8])
y = np.array([1, 4, 9, 16, 7, 11, 23, 18])
sizes = np.array([20,50,100,200,500,1000,60,90])
plt.figure(figsize=(8,8),dpi=80)
plt.scatter(x,y,s=sizes)
plt.show()
主要使用 bar()
方法来绘制柱形图。
bar() 方法语法格式如下:
plt.rcParams['font.sans-serif']=['SimHei'] # 用来正常显示中文标签
movie_names = ['雷神3:诸神黄昏','正义联盟','东方快车谋杀案','寻梦环游记','全球风暴', '降魔传','追捕','七十七天','密战','狂兽','其它']
tickets = [,,,,,8725,8716,8318,7916,6764,]
x = range(len(movie_names))
plt.figure(figsize=(20,8),dpi=80)
plt.bar(x,tickets,color=['b','g','r','c','m','y','k'])
plt.xticks(x,movie_names)
plt.title('电影票房收入对比')
plt.grid(linestyle='--',alpha=0.5)
plt.show()
plt.rcParams['font.sans-serif']=['SimHei'] # 用来正常显示中文标签
plt.rcParams['axes.unicode_minus'] = False # 用来正常显示负号
movie_name = ['雷神3:诸神黄昏','正义联盟','寻梦环游记']
first_day = [.6,.5,1275.7]
first_weekend=[.9,.6,]
plt.figure(figsize=(20,8),dpi=80)
x=range(3)
plt.bar(x,first_day,width=0.2,label='首日票房') # 绘制第一组柱状图
plt.bar([i+0.2 for i in x],first_weekend,width=0.2,label='首周票房') # 绘制第二组柱状图
plt.legend() # 绘制图例
plt.xticks([i+0.1 for i in x],movie_name) # 修改x轴刻度
plt.show()
垂直方向的柱状图可以使用barh()
方法来设置:
import matplotlib.pyplot as plt
x = ["Runoob-1", "Runoob-2", "Runoob-3", "C-RUNOOB"]
y = [12, 22, 6, 18]
plt.figure(figsize=(20,8),dpi=80)
plt.barh(x,y)
plt.show()
使用hist()
方法来绘制直方图
# 电影时长分布状况
time = [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, 117, 119, 105, 137, 123, 128, 125, 104, 109, 134, 125, 127,105, 120, 107, 129, 116, 108, 132, 103, 136, 118, 102, 120, 114,105, 115, 132, 145, 119, 121, 112, 139, 125, 138, 109, 132, 134,156, 106, 117, 127, 144, 139, 139, 119, 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, 111, 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, 114, 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, 111, 101, 110,105, 129, 137, 112, 120, 113, 133, 112, 83, 94, 146, 133, 101,131, 116, 111, 84, 137, 115, 122, 106, 144, 109, 123, 116, 111,111, 133, 150]
plt.figure(figsize=(20,8),dpi=80)
distince = 2 # 每组的间距
plt.hist(time,(max(time)-min(time))//distince)
plt.xticks(range(min(time),max(time)+2,distince))
plt.grid(linestyle='--',alpha=0.5)
plt.xlabel('电影时长大小')
plt.ylabel('电影的数据量')
plt.title("电影时长分布")
plt.show()
使用 pyplot 中的 pie()
方法来绘制饼图。
参数说明:
movie_name = ['雷神3:诸神黄昏','正义联盟','东方快车谋杀案','寻梦环游记','全球风暴','降魔传','追捕','七十七天','密战','狂兽','其它']
place_count = [,,,,,9945,7679,6799,6101,4621,]
plt.figure(figsize=(20,8),dpi=80)
plt.pie(place_count,labels=movie_name,autopct='%1.2f%%')
plt.legend()
plt.axis('equal') # 确保饼图能化成一个圆
plt.show()