【问题标题】:How to get scatter points for a scatter plot with different colors in accordance to a particular range如何根据特定范围获取具有不同颜色的散点图的散点
【发布时间】:2021-07-20 22:23:35
【问题描述】:

希望每个人在这些困难时期都做得很好。我正在尝试在底图上绘制带有散点的旋风轨迹。我绘制成功了,但我想要的是希望散点图根据一定的范围用不同的颜色绘制,例如黑色小于 17 节,蓝色在 17-27 节之间,青色在 27-33 节之间,在 33-47 绿色之间,在 47-63 之间橙色和大于 120 节红色。我能够用各种颜色绘制散点图,但不是根据范围。因此,如果有人可以通过向我展示如何做到这一点来帮助我,将不胜感激。 我使用的代码和生成的图附在下面。

import os
os.environ["PROJ_LIB"] = "C:\\Utilities\\Python\\Anaconda\\Library\\share"; #fixr
from mpl_toolkits.basemap import Basemap
import proplot as plot
import pandas as pd
import matplotlib as mpl
m=Basemap()
#dt = pd.read_excel('E:/tracks.xlsx',sheet_name='amp')
data = [25,25,35,40,45,55,70,80,100,120,125,130,125,115,105,100,95]
lon= [87,86.3,86.3,86.1,86,86,86,86.1,86.3,86.2,86.3,86.5,86.7,86.9,87,87.2,87.5]
lat= [10.4,10.9,10.9,11.1,11.4,11.5,12,12.5,13.2,13.4,14,14.9,15.6,16.5,17.4,18.4,19.1]
cmap = mpl.cm.get_cmap('bwr')
norm = mpl.colors.Normalize(vmin=25, vmax=130)
colors = cmap(norm(data))
x,y=m(lon,lat)
fig, axs = plot.subplots(ncols=1, axwidth=3, proj='merc', proj_kw={'lon_0': 180})
axs.format(
latlim=(0, 30), lonlim=(50, 100),linewidth=1,
gridlinewidth=0,coast=True, latlines=30, lonlines=60,)
l=axs.scatter(x,y,c=colors,s=10)
fig.colorbar(colors)

【问题讨论】:

    标签: python matplotlib scatter-plot matplotlib-basemap


    【解决方案1】:

    您可以使用ListedColormapBoundaryNorm 来生成您的自定义离散色条。以下是使用cartopy 的示例:

    import cartopy.crs as ccrs
    import matplotlib.pyplot as plt
    import matplotlib as mpl
    
    data = [25,25,35,40,45,55,70,80,100,120,125,130,125,115,105,100,95]
    lon = [87,86.3,86.3,86.1,86,86,86,86.1,86.3,86.2,86.3,86.5,86.7,86.9,87,87.2,87.5]
    lat = [10.4,10.9,10.9,11.1,11.4,11.5,12,12.5,13.2,13.4,14,14.9,15.6,16.5,17.4,18.4,19.1]
    
    cmap = mpl.colors.ListedColormap(['blue', 'cyan', 'green', 'orange'])
    norm = mpl.colors.BoundaryNorm([17, 27, 33, 47, 63], cmap.N) 
    cmap.set_under('black')
    cmap.set_over('red')
    colors = cmap(norm(data))
    
    fig, ax = plt.subplots(figsize=(10, 5), subplot_kw={'projection': ccrs.PlateCarree()})
    ax.coastlines() # draw coastlines
    ax.set_extent([65, 95, 5, 25]) # zoom into India
    ax.scatter(lon, lat, s=20, c=colors, cmap=cmap, norm=norm, transform=ccrs.Geodetic())
    fig.colorbar(mpl.cm.ScalarMappable(norm, cmap), extend='both')
    

    【讨论】:

    • 感谢您的帮助。我按照你说的做了,但是得到一个错误“ValueError:输入映射必须是一个matplotlib艺术家、对象列表、颜色列表或颜色图。得到。”
    • @DebashisPaul 是在集成回您的真实代码后吗?或者您仅使用我的示例代码就遇到了这个错误?
    • 整合回真实代码后报错
    • 是的,示例代码可以工作,但在与原始代码集成后出现错误。
    • 感谢您的帮助。是的,这就是我想要的。
    猜你喜欢
    • 2019-11-03
    • 2017-09-14
    • 1970-01-01
    • 2021-07-13
    • 1970-01-01
    • 1970-01-01
    • 2020-07-03
    • 1970-01-01
    • 2018-06-03
    相关资源
    最近更新 更多