python - 获取上下文 basemap 以填充地 block

标签 python geopandas contextily

我正在尝试使用以下内容创建一个 2x2 子图:

import geopandas as gpd
import matplotlib.pyplot as plt
import contextily as ctx

site = gdf.groupby('Site_name')

plt.figure(figsize =(20,20))

# Iterate through sites

for i, (Site_name, site_gdf) in enumerate(site):
    # create subplot axes in a 2x2 grid
    ax = plt.subplot(2, 2, i + 1) # nrows, ncols, axes position
    # plot the site on these axes
    site_gdf.plot(ax=ax)
    ctx.add_basemap(ax, source=ctx.providers.Esri.WorldImagery)
    # set the title
    ax.set_title(Site_name)
    # set the aspect
    # adjustable datalim ensure that the plots have the same axes size
    ax.set_aspect('equal', adjustable='datalim')

plt.tight_layout()
plt.show()

出现的问题是子图中的 basemap 范围仅限于叠加点数据。我该如何更改它,以便每个子图都有一个覆盖整个子图的 basemap 。

Plot output

最佳答案

我的解决方案是,我搜索了最外层的点,然后用 更改了我的 matplotlib 轴

ax.set_xlim(x_min-addition, x_max+addition)
ax.set_ylim(y_min-addition, y_max+addition)

在这种情况下,加法只是增加点数的数字,例如 0.001。 x_min 是最小的点,x_max 是最大的点,依此类推......然后,我得到了我的 basemap 。

ctx.add_basemap(ax,...)

如果您知道所有点的最外层边界,则可以直接通过它们。结果应该是相同的大小。如果您不知道自己的界限,则需要先找到它们。 因此,您可以遍历您的观点并比较它们(只是一个例子):

for point_data_x, point_data_y in site_data:
    if point_data_x < x_min:
        x_min = point_data_x
    elif point_data_x > x_max:
        x_max = point_data_x
    if point_data_y < y_min:
        y_min = point_data_y
    elif point_data_y > y_max:
        y_max = point_data_y

亲切的问候

关于python - 获取上下文 basemap 以填充地 block ,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/63631446/

相关文章:

python - 如何从python中的dll加载具有自定义接口(interface)的COM对象?

python - 如何有效地将数据从 geopandas 保存到 django(从 shapely 转换为 geodjango)?

python - 打开街道 map (pyproj)。如何解决语法问题?

python - 发生异常 : SSLError when adding basemap with Contextily to GeoPandas map

python - 具有相同大小图的 seaborn jointplot

python - Pandas 中 transpose() 和 .T 的区别

javascript - 安卓 SL4A : how to link to relative scripts in HTML/javascript app?

python - 计算包含两个较小圆的最小圆的圆心和半径

python - 如何转换 Pandas 中的纬度/经度点并查看它们是否落在某些边界多边形中?

python - 将嵌套的坐标列表转换为形状多边形