1 绘制普通图像
2 绘制柱状图
3 绘制散点图
(1)绘制普通图像
demo1
import matplotlib.pyplot as plt
import numpy as np
# 绘制普通图像
x = np.linspace(-1, 1, 50)
y = 2 * x + 1
plt.plot(x, y)
plt.show()
# 绘制普通图像
y = x**2
plt.plot(x, y)
plt.show()
结果
data:image/s3,"s3://crabby-images/a0c91/a0c912f03972a6fb5ffcde1b559a4313030b91e7" alt=""
demo2
# figure的使用
x = np.linspace(-1, 1, 50)
y1 = 2 * x + 1
# figure 1
plt.figure()
plt.plot(x, y1)
# figure 2
y2 = x**2
plt.figure()
plt.plot(x, y2)
# figure 3,指定figure的编号并指定figure的大小, 指定线的颜色, 宽度和类型
y2 = x**2
plt.figure(num = 5, figsize = (4, 4))
plt.plot(x, y1)
plt.plot(x, y2, color = 'red', linewidth = 1.0, linestyle = '--')
plt.show()
结果
data:image/s3,"s3://crabby-images/d0523/d05230b290dde86bf1265c47564806d1c764ab96" alt=""
data:image/s3,"s3://crabby-images/3ff56/3ff56f41b1d706d516753e3824a4e539ea338259" alt=""
demo3 设置坐标轴
import matplotlib.pyplot as plt
import numpy as np
# 绘制普通图像
x = np.linspace(-1, 1, 50)
y1 = 2 * x + 1
y2 = x**2
plt.figure()
plt.plot(x, y1)
plt.plot(x, y2, color = 'red', linewidth = 1.0, linestyle = '--')
# 设置坐标轴的取值范围
plt.xlim((-1, 1))
plt.ylim((0, 2))
# 设置坐标轴的lable
plt.xlabel('X axis')
plt.ylabel('Y axis')
# 设置x坐标轴刻度, 原来为0.25, 修改后为0.5
plt.xticks(np.linspace(-1, 1, 5))
# 设置y坐标轴刻度及标签, $$是设置字体
plt.yticks([0, 0.5], ['$minimum$', 'normal'])
plt.show()
结果
data:image/s3,"s3://crabby-images/a5b4d/a5b4dc0f14fc60e51e2fb794d788bd6fc4bbb70f" alt=""
demo4 设置legend图例
import matplotlib.pyplot as plt
import numpy as np
# 绘制普通图像
x = np.linspace(-1, 1, 50)
y1 = 2 * x + 1
y2 = x**2
plt.figure()
# 在绘制时设置lable, 逗号是必须的
l1, = plt.plot(x, y1, label = 'line')
l2, = plt.plot(x, y2, label = 'parabola', color = 'red', linewidth = 1.0, linestyle = '--')
# 设置坐标轴的取值范围
plt.xlim((-1, 1))
plt.ylim((0, 2))
# 设置坐标轴的lable
plt.xlabel('X axis')
plt.ylabel('Y axis')
# 设置x坐标轴刻度, 原来为0.25, 修改后为0.5
plt.xticks(np.linspace(-1, 1, 5))
# 设置y坐标轴刻度及标签, $$是设置字体
plt.yticks([0, 0.5], ['$minimum$', 'normal'])
# 设置legend
plt.legend(handles = [l1, l2,], labels = ['a', 'b'], loc = 'best')
plt.show()
结果:
data:image/s3,"s3://crabby-images/c971d/c971d1542e7baf2302f86b4d9f5de8eb642d869d" alt=""
(2)绘制柱状图
demo1基本柱状图
import matplotlib.pyplot as plt
data = [5, 20, 15, 25, 10]
plt.bar(range(len(data)), data)
plt.show()
结果
data:image/s3,"s3://crabby-images/8d947/8d947b19bb6fd1489d8328e43ecc2c8295a3bab1" alt=""
plt.bar 函数签名为:
bar(left, height, width=0.8, bottom=None, **kwargs)
事实上,left,height,width,bottom这四个参数确定了柱体的位置和大小。默认情况下,left为柱体的居中位置(可以通过align参数来改变left值的含义
demo2设置柱体样式
通过 facecolor(或fc) 关键字参数可以设置柱体颜色,例如:
import matplotlib.pyplot as plt
data = [5, 20, 15, 25, 10]
plt.bar(range(len(data)), data, fc='g')
plt.show()
data:image/s3,"s3://crabby-images/168ee/168ee2053783c5021b56c7b94d8a8c3341ba0147" alt=""
通过 color 关键字参数 可以一次性设置多个颜色,例如:
import matplotlib.pyplot as plt
data = [5, 20, 15, 25, 10]
plt.bar(range(len(data)), data, color='rgb') # or `color=['r', 'g', 'b']`
plt.show()
data:image/s3,"s3://crabby-images/1e965/1e9659833c4387da1057b0fde2ca6c42e4aae616" alt=""
demo3 设置tick label
import matplotlib.pyplot as plt
data = [5, 20, 15, 25, 10]
labels = ['Tom', 'Dick', 'Harry', 'Slim', 'Jim']
plt.bar(range(len(data)), data, tick_label=labels)
plt.show()
file:///home/tong/%E5%9B%BE%E7%89%87/2017-12-14%2017-18-17%20%E7%9A%84%E5%B1%8F%E5%B9%95%E6%88%AA%E5%9B%BE.png
demo3 并列柱状图
import numpy as np
import matplotlib.pyplot as plt
size = 5
x = np.arange(size)
a = np.random.random(size)
b = np.random.random(size)
c = np.random.random(size)
total_width, n = 0.8, 3
width = total_width / n
x = x - (total_width - width) / 2
plt.bar(x, a, width=width, label='a')
plt.bar(x + width, b, width=width, label='b')
plt.bar(x + 2 * width, c, width=width, label='c')
plt.legend()
plt.show()
data:image/s3,"s3://crabby-images/14abe/14abe5c903d7d146430da5e27808d08bdd58ad92" alt=""
(3)绘制散点图
demo1
import numpy as np
import matplotlib.pyplot as plt
N = 1000
x = np.random.randn(N)
y = np.random.randn(N)
plt.scatter(x, y)
plt.show()
data:image/s3,"s3://crabby-images/0d8b7/0d8b7743733d73abea485b2e56062e95081ca8d1" alt=""
demo2
import numpy as np
import matplotlib.pyplot as plt
N = 1000
x = np.random.randn(N)
y = np.random.randn(N)
color = ['r','y','k','g','m']
plt.scatter(x, y,c=color,marker='>')
plt.show()
data:image/s3,"s3://crabby-images/3603c/3603c209899d77291716263b8a8ec3189d158142" alt=""
demo3
alpha:标量,可选,默认值:无, 0(透明)和1(不透明)之间的alpha混合值
import numpy as np
import matplotlib.pyplot as plt
N = 1000
x = np.random.randn(N)
y = np.random.randn(N)
plt.scatter(x, y,alpha=0.5)
plt.show()
data:image/s3,"s3://crabby-images/5b75e/5b75e589af8d8670ae74e0259a90ce7fa9dde822" alt=""
网友评论