mateplotlib绘制散点图_使用matplotlib绘制散点图

本文介绍了如何使用matplotlib的scatter函数绘制散点图,包括设置散点的坐标、大小、颜色、透明度、形状,以及在同一图表上绘制多组数据,并展示了如何添加图例。
摘要由CSDN通过智能技术生成

在matplotlib中使用函数 matplotlib.pyplot.scatter 绘制散点图,matplotlib.pyplot.scatter的函数签名如下:

matplotlib.pyplot.scatter(x, y, s=None, c=None, marker=None, cmap=None, norm=None, vmin=None, vmax=None, alpha=None, linewidths=None, verts=None, edgecolors=None, hold=None, data=None, **kwargs)

常用参数有:x,y组成了散点的坐标;s为散点的面积;c为散点的颜色(默认为蓝色'b');marker为散点的标记;alpha为散点的透明度(0与1之间的数,0为完全透明,1为完全不透明);linewidths为散点边缘的线宽;如果marker为None,则使用verts的值构建散点标记;edgecolors为散点边缘颜色。

其他参数如cmap为colormap;norm为数据亮度;vmin、vmax和norm配合使用用来归一化亮度数据,这些与数据亮度有关,可以参考这篇文章。

下面为常见的用法:

1、绘制普通散点图

import matplotlib

import matplotlib.pyplot as plt

import numpy as np

# 保证图片在浏览器内正常显示

%matplotlib inline

# 10个点

N = 10

x = np.random.rand(N)

y = np.random.rand(N)

plt.scatter(x, y)

plt.show()

输出:

2b05bbdd6799c820b507413ab0968308.png

2、更改散点的大小

import matplotlib

import matplotlib.pyplot as plt

import numpy as np

# 保证图片在浏览器内正常显示

%matplotlib inline

# 10个点

N = 10

x = np.random.rand(N)

y = np.random.rand(N)

# 每个点随机大小

s = (30*np.random.rand(N))**2

plt.scatter(x, y, s=s)

plt.show()

输出:

3f3d9603311b089b2069400b4dc5f791.png

3、更改散点颜色和透明度

import matplotlib

import matplotlib.pyplot as plt

import numpy as np

# 保证图片在浏览器内正常显示

%matplotlib inline

# 10个点

N = 10

x = np.random.rand(N)

y = np.random.rand(N)

# 每个点随机大小

s = (30*np.random.rand(N))**2

# 随机颜色

c = np.random.rand(N)

plt.scatter(x, y, s=s, c=c, alpha=0.5)

plt.show()

输出:

9bb0fec1eb2a5edd12c8b0a192af87cf.png

4、更改散点形状

import matplotlib.pyplot as plt

import numpy as np

# 保证图片在浏览器内正常显示

%matplotlib inline

# 10个点

N = 10

x = np.random.rand(N)

y = np.random.rand(N)

s = (30*np.random.rand(N))**2

c = np.random.rand(N)

plt.scatter(x, y, s=s, c=c, marker='^', alpha=0.5)

plt.show()

5、在一张图上绘制两组数据的散点

import matplotlib.pyplot as plt

import numpy as np

# 保证图片在浏览器内正常显示

%matplotlib inline

# 10个点

N = 10

x1 = np.random.rand(N)

y1 = np.random.rand(N)

x2 = np.random.rand(N)

y2 = np.random.rand(N)

plt.scatter(x1, y1, marker='o')

plt.scatter(x2, y2, marker='^')

plt.show()

输出:

e690d4a41ffcd0809b055fe8385565b3.png

6、为散点设置图例

import matplotlib.pyplot as plt

import numpy as np

# 保证图片在浏览器内正常显示

%matplotlib inline

# 10个点

N = 10

x1 = np.random.rand(N)

y1 = np.random.rand(N)

x2 = np.random.rand(N)

y2 = np.random.rand(N)

plt.scatter(x1, y1, marker='o', label="circle")

plt.scatter(x2, y2, marker='^', label="triangle")

plt.legend(loc='best')

plt.show()

输出:

9aff908baaab14cc33fc5752d03675bd.png

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值