利用Python栅格化地图(以成都市为例,含代码)
Python中可以使用多种库来进行栅格化地图的操作,其中比较常用的有geopandas、rasterio等,文中通过代码介绍的非常详细,需要的朋友可以参考下
python代码实现
读取成都市边界的图层文件(.shp),并可视化
import geopandas as gpd cd_shape = gpd.read_file('Chengdu/Chengdu.shp') cd_shape.plot(edgecolor='k',facecolor='none')
下面这个栅格地图的类是我自己写的,类的参数主要有
rasterDataPath
:图层文件的路径length
:栅格单元的长度,单位为 m
class RasterData: def __init__(self, raster_data_path: str, length: float): self.raster = gpd.read_file(raster_data_path) self.length = length/1000 * 0.009 self.polygons = [] self.grid_ids = [] self.x_min, self.y_min, self.x_max, self.y_max = self.raster.total_bounds self.rows, self.cols = self.grid_shape() def grid_shape(self) -> tuple: rows = int(math.ceil((self.y_max - self.y_min) / float(self.length))) cols = int(math.ceil((self.x_max - self.x_min) / float(self.length))) return rows, cols def grid_num(self) -> int: return self.rows * self.cols def grid_map(self) -> gpd.GeoDataFrame: points_list = [] for row in range(self.rows): for col in range(self.cols): center_point_x = self.x_min + self.length / 2 + col * self.length center_point_y = self.y_min + self.length / 2 + row * self.length points = [Point(center_point_x + dx * self.length / 2, center_point_y + dy * self.length / 2) for dx, dy in [(-1, 1), (1, 1), (1, -1), (-1, -1)]] points_list.append(points) polygons = [Polygon(points) for points in points_list] grid_ids = list(range(len(polygons))) grid = gpd.GeoDataFrame({'geometry': polygons, 'grid_id': grid_ids}, crs=self.raster.crs) return grid # 计算栅格与区域的交集 def grid_intersection(self, region: gpd.GeoDataFrame) -> gpd.GeoDataFrame: grid = self.grid_map() intersection_data = gpd.overlay(grid, region, how='intersection') return intersection_data
实例化对象并调用grid_map
方法
grid = RasterData('Chengdu/Chengdu.shp', 2000) # 实例化对象 grid_data = grid.grid_map() # 调用grid_map方法进行栅格化 # 将两个图层绘制在一起 fig, ax = plt.subplots(figsize=(10, 10)) # 加粗绘图的线宽 cd_shape.plot(ax=ax, edgecolor='k', linewidth=1, facecolor='none') grid_data.plot(ax=ax, edgecolor='k', linewidth=0.5, facecolor='none')
得到栅格模型,但此时的栅格是根据成都市边界的最大范围进行划分的,很多时候我们需要的是地理边界内部的栅格,因此需要调用grid_intersection
方法
# 将两个图层绘制在一起 fig, ax = plt.subplots(figsize=(10, 10)) # 加粗绘图的线宽 intersection_data = grid.grid_intersection(cd_shape) cd_shape.plot(ax=ax, edgecolor='k', linewidth=1, facecolor='none') intersection_data.plot(ax=ax, edgecolor='k', linewidth=0.5, facecolor='none')
最终就得到了栅格化后的数据,是DataFrame
格式的,其中grid_id
代表栅格编号,geometry
代码当前栅格的多边形要素
总结
到此这篇关于利用Python栅格化地图的文章就介绍到这了,更多相关Python栅格化地图内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
相关文章
手机使用python操作图片文件(pydroid3)过程详解
这篇文章主要介绍了手机使用python操作图片文件(pydroid3)过程详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下2019-09-09python解决Missing 1 required positional ar
这篇文章主要介绍了python解决Missing 1 required positional argument报错问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教2023-12-12解决phantomjs截图失败,phantom.exit位置的问题
今天小编就为大家分享一篇解决phantomjs截图失败,phantom.exit位置的问题,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧2018-05-05python基础教程之popen函数操作其它程序的输入和输出示例
popen函数允许一个程序将另一个程序作为新进程启动,并可以传递数据给它或者通过它接收数据,下面使用示例学习一下他的使用方法2014-02-02Python编程实现生成特定范围内不重复多个随机数的2种方法
这篇文章主要介绍了Python编程实现生成特定范围内不重复多个随机数的2种方法,涉及Python基于random生成随机数的常见操作技巧,需要的朋友可以参考下2017-04-04
最新评论