我想制作一个散点图(使用matplotlib),其中点根据第三个变量进行着色。我已经接近成功了:
plt.scatter(w, M, c=p, marker='s')
w 和 M 是数据点,p 是我想要进行阴影处理的变量。
然而,我想使用灰度而不是彩色。有人能帮忙吗?
我想制作一个散点图(使用matplotlib),其中点根据第三个变量进行着色。我已经接近成功了:
plt.scatter(w, M, c=p, marker='s')
w 和 M 是数据点,p 是我想要进行阴影处理的变量。
然而,我想使用灰度而不是彩色。有人能帮忙吗?
不需要手动设置颜色。相反,指定灰度色彩地图即可...
import numpy as np
import matplotlib.pyplot as plt
# Generate data...
x = np.random.random(10)
y = np.random.random(10)
# Plot...
plt.scatter(x, y, c=y, s=500) # s is a size of marker
plt.gray()
plt.show()
或者,如果您希望有更广泛的颜色映射,您也可以指定cmap
关键字参数来使用scatter
函数。要使用这些颜色映射的反转版本,只需指定其中任何一个的“_r
”版本即可。例如,使用gray_r
代替gray
。 有几个不同的灰度颜色映射预设(例如gray
、gist_yarg
、binary
等)。
import matplotlib.pyplot as plt
import numpy as np
# Generate data...
x = np.random.random(10)
y = np.random.random(10)
plt.scatter(x, y, c=y, s=500, cmap='gray')
plt.show()
c = '0.1'
然后你可以将第三个变量转换为此范围内的值,并使用它来给你的点着色。from matplotlib import pyplot as plt
x = [1, 2, 3, 4, 5, 6, 7, 8, 9]
y = [125, 32, 54, 253, 67, 87, 233, 56, 67]
color = [str(item/255.) for item in y]
plt.scatter(x, y, s=500, c=color)
plt.show()
c
参数,并在第四列中提供 alpha 值,则可以将 ALPHA 应用为一种颜色映射。 如果第三个变量是Z,且形状为 (n,1),则 colors = numpy.hstack((numpy.zeros_like(z), numpy.zeros_like(z), numpy.ones_like(z), z/z.max()))
会产生非常好的效果(当然可以进行微调)。 - heltonbikerplt.colorbar()
会做到这一点。 - Mathew Savage有时您可能需要根据x值准确地绘制颜色。例如,您可能会拥有一个包含3种类型变量和一些数据点的数据框。并且您想要执行以下操作
在这种情况下,您可能需要编写一个简短的函数来将x值映射到相应的颜色名称列表,然后将该列表传递给plt.scatter
命令。
x=['A','B','B','C','A','B']
y=[15,30,25,18,22,13]
# Function to map the colors as a list from the input list of x variables
def pltcolor(lst):
cols=[]
for l in lst:
if l=='A':
cols.append('red')
elif l=='B':
cols.append('blue')
else:
cols.append('green')
return cols
# Create the colors list using the function above
cols=pltcolor(x)
plt.scatter(x=x,y=y,s=500,c=cols) #Pass on the list created by the function here
plt.grid(True)
plt.show()
fig, ax = plt.subplots(nrows=1, ncols=1, figsize=(8,8))
p = ax.scatter(x, y, c=y, cmap='cmo.deep')
fig.colorbar(p,ax=ax,orientation='vertical',label='labelname')
mpl.cm
也可以直接使用plt.cm
来调用。 - heltonbikerplt.contour()
或plt.contourf()
绘制 -- 但这是一个不同的问题。 - Zak