matplotlib的基本用法(七)——绘制散点图

文章作者:Tyan
博客:noahsnail.com  |  CSDN  |  简书

本文主要使用matplotlib进行散点图的绘制。

  • Demo
import numpy as np
import matplotlib.pyplot as plt

# 数据个数
n = 1024
# 均值为0, 方差为1的随机数
x = np.random.normal(0, 1, n)
y = np.random.normal(0, 1, n)

# 计算颜色值
color = np.arctan2(y, x)
# 绘制散点图
plt.scatter(x, y, s = 75, c = color, alpha = 0.5)
# 设置坐标轴范围
plt.xlim((-1.5, 1.5))
plt.ylim((-1.5, 1.5))

# 不显示坐标轴的值
plt.xticks(())
plt.yticks(())

plt.show()
  • 结果

散点图

参考资料

  1. https://www.youtube.com/user/MorvanZhou
  • 1
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Cartopy 是一个专门用于地图绘制的 Python 包,支持多种地图投影方式,包括等距平面投影、矢量和栅格数据的投影转换、地图要素绘制等功能。本文将简单介绍 Cartopy 的基本用法,以绘制经纬度数据为例。 首先安装 Cartopy: ``` pip install cartopy ``` 然后导入需要的模块: ```python import matplotlib.pyplot as plt import cartopy.crs as ccrs import cartopy.feature as cfeature ``` 其中,`ccrs` 模块定义了各种地图投影方式,`cfeature` 模块提供了一些常用的地图要素,如海岸线、国家边界等。 接下来,我们可以使用 `ccrs.PlateCarree()` 定义经纬度投影方式,然后使用 `plt.subplots()` 创建一个画布和子图,再在子图上使用 `add_feature()` 方法添加地图要素: ```python fig, ax = plt.subplots(subplot_kw=dict(projection=ccrs.PlateCarree())) ax.add_feature(cfeature.COASTLINE) ax.add_feature(cfeature.BORDERS) ax.add_feature(cfeature.LAKES, alpha=0.5) ax.add_feature(cfeature.RIVERS) ax.set_extent([70, 140, 15, 55]) plt.show() ``` 这里我们添加了海岸线、国家边界、湖泊和河流等要素,并通过 `set_extent()` 方法指定了地图范围。 最后,我们可以使用 `scatter()` 方法在地图上绘制散点图: ```python import numpy as np lons = np.random.randint(70, 140, size=100) lats = np.random.randint(15, 55, size=100) data = np.random.rand(100) fig, ax = plt.subplots(subplot_kw=dict(projection=ccrs.PlateCarree())) ax.add_feature(cfeature.COASTLINE) ax.add_feature(cfeature.BORDERS) ax.add_feature(cfeature.LAKES, alpha=0.5) ax.add_feature(cfeature.RIVERS) ax.set_extent([70, 140, 15, 55]) ax.scatter(lons, lats, c=data, transform=ccrs.PlateCarree()) plt.show() ``` 这里生成了一组随机的经纬度数据,并使用 `scatter()` 方法在地图上绘制出来。 完整代码如下: ```python import matplotlib.pyplot as plt import cartopy.crs as ccrs import cartopy.feature as cfeature import numpy as np lons = np.random.randint(70, 140, size=100) lats = np.random.randint(15, 55, size=100) data = np.random.rand(100) fig, ax = plt.subplots(subplot_kw=dict(projection=ccrs.PlateCarree())) ax.add_feature(cfeature.COASTLINE) ax.add_feature(cfeature.BORDERS) ax.add_feature(cfeature.LAKES, alpha=0.5) ax.add_feature(cfeature.RIVERS) ax.set_extent([70, 140, 15, 55]) ax.scatter(lons, lats, c=data, transform=ccrs.PlateCarree()) plt.show() ```

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值