Pyplot入门教程及本文实例参考文档 Pyplot tutorial
绘制(0,0),(1,1),(2,1),(3,3)四个点连成的折线
import matplotlib.pyplot as plt
x=[0,1,2,3]
y=[0,1,1,3]
plt.plot(x,y)
plt.show()
plt.plot(x,y,'r') # 修改颜色,rgb=红绿蓝,默认为蓝
plt.plot(x,y,'--') # 修改线的形状为虚线,默认为折线'-',另外'o'为点,'^'为三角
plt.plot(x,y,'g--') # 一起修改为绿色虚线
plt.axis([1,6,0,5]) # 修改坐标轴x刻度显示
plt.plot(x,y)接受点集(x,y),当只输入一维数据的时候当作y轴处理,x轴默认生成[0,1,2,…]
例如,绘制4个独立的点(0,1),(1,1),(2,1),(3,1)
y=[1,1,1,1]
plt.plot(y,'ro')
plt.show()
教程原文
If matplotlib were limited to working with lists, it would be fairly useless for numeric processing. Generally, you will use numpy arrays. In fact, all sequences are converted to numpy arrays internally.
考虑到性能问题,意味着所有的序列(包括list等)会在内部转换为numpy.array
t1=[1,5,1,5] #list会被转换为t2的类型
t2=np.array([5,1,5,1]) #numpy.array
plt.plot(t1)
plt.plot(t2)
plt.show()
在4中,分别使用了两次plt.plot()载入t1和t2,也可以用一条语句
plt.plot(t1,'b--',t2,'r--')
对于两组(x,y)坐标,如下
x1=[1,2,3,4]
y1=[1,2,3,4]
x2=[2,4,6,8]
y2=[4,8,12,16]
plt.plot(x1,y1,'r-',x2,y2,'g--')
plt.show()
绘制f(x)=sin(x) 和g(x)=cos(x) 在x∈[0,20]中的图像
x = np.arange(0, 20, 0.01)
plt.plot(x, np.sin(x), 'r-', x, np.cos(x), 'b--')
plt.axis([0,20,-3,3])
plt.show()
x = np.arange(0, 20, 0.01)
plt.plot(x, x**2)
plt.grid(True) # 设置网格线
plt.show()
以7中的函数图像为例.注意,输入中文会出现方块乱码
(1)增加x,y轴文字
plt.xlabel("Money Earned")
plt.ylabel("Consume Level")
(2)增加标题
plt.title("Figure.1")
(3).图内文字
指定首字出现的x轴,y轴,文字本身
plt.text(2.5,100,"TEXT1")
(4)箭头指示
指定文字,箭头指向的坐标,文字显示的坐标,箭头的属性
plt.annotate('max value', xy=(20, 400), xytext=(12.5, 400),
arrowprops=dict(facecolor='black', shrink=0.05),
)
(5)综合结果图
对text(),xlabel(),ylabel(),title(),annotate()等可使用参数设置文本属性
例如
plt.xlabel("Money Earned",color="r",fontsize=20)
可选参数如下,这里只列出常用属性,更多属性请查阅
https://matplotlib.org/api/text_api.html#matplotlib.text.Text
plt.plot()返回matplotlib.lines.Line2D,可以通过变量获得并修改曲线Line2D的属性
x=np.arange(0,10,0.01)
line1,line2=plt.plot(x,np.sin(x),'-',x,np.cos(x),'--') #line1得到2D Lines
plt.setp(line1,color='r',linewidth='11.0') #设置曲线的宽度
plt.show()
利用9中修改字体为中文字体就能轻松解决乱码
(1)指定为文件目录中的字体
from matplotlib.font_manager import FontProperties
font = FontProperties(fname=r"c:\windows\fonts\simsun.ttc")
plt.xlabel("中文文本", fontproperties=font)
(2)指定为系统字体
plt.xlabel("中文文本",fontname='SimHei',size=20)
#或者
plt.xlabel("中文文本",fontproperties='SimHei',fontsize=20)#size要放在后面,否则会被覆盖
(3)全局设置
font = {'family' : 'SimHei',
'weight' : '50',
'size' : '30'}
plt.rc('font', **font)
plt.xlabel("中文文本")
(1)指定刻度范围
plt.axis([0,6,1,5]) #设定x轴刻度在(0,6) y轴刻度在(1,5)
plt.axis('off') #关闭刻度
(2)子图的刻度修改
axes[0,0].set_xticks([0,250,750,1000]) #设置x轴
axes[0,0].set_xticklabels(['one','two','three'],rotation=30) #将数值改为标签,并旋转30度显示
(3)使用刻度函数
以教程例子为例
四种不同的刻度
plt.yscale('linear')
plt.yscale('log')
plt.yscale('symlog')
plt.yscale('logit')
上述四图的例子代码如下
from matplotlib.ticker import NullFormatter # useful for `logit` scale
# Fixing random state for reproducibility
np.random.seed(19680801)
# make up some data in the interval ]0, 1[
y = np.random.normal(loc=0.5, scale=0.4, size=1000)
y = y[(y > 0) & (y < 1)]
y.sort()
x = np.arange(len(y))
# plot with various axes scales
plt.figure(1)
# linear
plt.subplot(221)
plt.plot(x, y)
plt.yscale('linear')
plt.title('linear')
plt.grid(True)
# log
plt.subplot(222)
plt.plot(x, y)
plt.yscale('log')
plt.title('log')
plt.grid(True)
# symmetric log
plt.subplot(223)
plt.plot(x, y - y.mean())
plt.yscale('symlog', linthreshy=0.01)
plt.title('symlog')
plt.grid(True)
# logit
plt.subplot(224)
plt.plot(x, y)
plt.yscale('logit')
plt.title('logit')
plt.grid(True)
# Format the minor tick labels of the y-axis into empty strings with
# `NullFormatter`, to avoid cumbering the axis with too many labels.
plt.gca().yaxis.set_minor_formatter(NullFormatter())
# Adjust the subplot layout, because the logit one may take more space
# than usual, due to y-tick labels like "1 - 10^{-3}"
plt.subplots_adjust(top=0.92, bottom=0.08, left=0.10, right=0.95, hspace=0.25,
wspace=0.35)
plt.show()
import matplotlib.pyplot as plt
import matplotlib.patches as patches
fig = plt.figure()
ax1 = fig.add_subplot(111,aspect='equal') #1x1一张图中的第1张,equal为等宽显示
rec=patches.Rectangle((0, 0), 8, 4) #顶点坐标(0,0) 宽w=8 高h=4
cir=patches.Circle((8,8),2) #圆心坐标(8,8) 半径r=1
ell=patches.Ellipse((2,8),6,3) #椭圆左顶点坐标(2,8) 长轴c1=6 短轴c2=3
ax1.add_patch(rec) #插入patch图像
ax1.add_patch(cir)
ax1.add_patch(ell)
plt.plot() #显示多个
plt.show()
patches中还有许多种图形,例如各种箭头,箭,多边形等.
plt.hist()用于绘制直方图
标准正态分布又称为μ分布,是以均数μ=0、标准差σ=1的正态分布,记为N(0,1)
代码如下
mu, sigma = 0,1
x = np.random.normal(mu,sigma,10000)
n, bins, patches = plt.hist(x,bins=100,facecolor='g', alpha=0.75)
plt.text(-3, 250, r'$\mu=0,\ \sigma=1$')
plt.grid(True)
plt.show()
plt.scatter()用于绘制散点图
例:绘制正态分布随机1000个点的位置分布
x = np.random.normal(0, 1, 1000) # 1000个点的x坐标
y = np.random.normal(0, 1, 1000) # 1000个点的y坐标
c = np.random.rand(1000) #1000个颜色
s = np.random.rand(100)*100 #100种大小
plt.scatter(x, y, c=c, s=s,alpha=0.5)
plt.grid(True)
plt.show()
names = ['Anime', 'Comic', 'Game']
values = [30, 10, 20]
plt.subplot(221) #构建2x2张图中的第1张子图
plt.bar(names, values) #统计图
plt.subplot(222)
plt.scatter(names, values) #散点图
plt.subplot(223)
plt.plot(names, values) #折线图
plt.suptitle('三种图示',fontname='SimHei')
plt.show()
上述是每次构造一个子图,然后在子图中绘制.也可以先构造所有的子图,再通过下标指定在哪张子图中绘制
fig,axes=plt.subplots(2,2) #构造2x2的子图
axes[0,1].plot(names, values) #通过下标访问
axes[1,0].scatter(names, values)
axes[1,1].bar(names, values)
plt.show()
fig,axes=plt.subplots(2,2,sharex=True,sharey=True) #构造2x2的子图,子图共享x,y轴
for i in range(2):
for j in range(2):
axes[i,j].hist(np.random.rand(500),bins=100,alpha=0.7,color='k')
plt.subplots_adjust(hspace=0,wspace=0) #修改内部的宽,高间距为0
plt.show()
(在python3.7中无法得到和书中一致的结果,即实现没有内部子图间隔的数据可视化)
垂直柱状图plt.bar(name,values)
水平柱状图plt.barh(name,values)
x=np.random.randint(1,10,8)
label=list('abcdefgh')
plt.subplot(211)
plt.bar(label,x)
plt.subplot(212)
plt.barh(label,x)
plt.show()
两组数据比较的垂直柱状图
这里不再使用plt.bar(),而是使用pd.DataFrame.plot.bar()
x=np.random.randint(1,10,8)
y=np.random.randint(1,10,8)
data=pd.DataFrame([x,y],index=['X','Y'],columns=list('abcdefgh'))
>>> data
data
a b c d e f g h
X 6 2 9 5 5 2 7 7
Y 6 6 9 1 1 5 2 4
data.plot.bar()
plt.show()
得到以index为分类,columns为数据的柱状图
两组数据交叉比较的垂直柱状图,只需交换index和columns即可
data.transpose().plot.bar() #data.transpose()转置
plt.show()