Объединение мультиполигонов OSMnx - PullRequest
0 голосов
/ 14 сентября 2018

Каковы лучшие практики создания объединения мультиполигонов, приобретенных в качестве группы, с использованием OSMnx '* gdf_from_places () ?

В gboeing * 02-example-osm-to-shapefile.ipynb несколько шейп-файлов загружаются из OSM в геоданные, используя метод gdf_from_places (). Геометрия сохраняется как мультиполигоны в кадре данных Geopanda, где каждая строка представляет место.

# you can pass multiple queries with mixed types (dicts and strings)
mx_gt_tx = ox.gdf_from_places(queries=[{'country':'Mexico'}, 'Guatemala', {'state':'Texas'}])
mx_gt_tx = ox.project_gdf(mx_gt_tx)
fig, ax = ox.plot_shape(mx_gt_tx)

osmnx gdf_from_places example

Что касается вопроса, я экспериментировал с использованием Geopanda GeoSeries.unary_union , но хотел узнать, как другие программно достигли этого в Python.

Текущий процесс 2018

В этом методе используется функция Shapely unary_union (иначе это будет mx_gt_tx ["geometry"]. Unary_union через Geopandas, как указано в комментарии @joris.

queries = [{'country':'Mexico'}, 'Guatemala', {'state':'Texas'}]

# buffer_dist is in meters
mx_gt_tx = ox.gdf_from_places(queries, gdf_name='region_mx_gt_tx')
mx_gt_tx

Imgur

# project the geometry to the appropriate UTM zone then plot it
mx_gt_tx = ox.project_gdf(mx_gt_tx)
fig, ax = ox.plot_shape(mx_gt_tx)

Imgur

# unary union through Geopandas
region_mx_gt_tx = gpd.GeoSeries(unary_union(mx_gt_tx["geometry"]))
region_mx_gt_tx.plot(color = 'blue')
plt.show()
print(region_mx_gt_tx )

Imgur

1 Ответ

0 голосов
/ 19 сентября 2018
import osmnx as ox
gdf = ox.gdf_from_places(queries=[{'country':'Mexico'}, 'Guatemala', {'state':'Texas'}])
unified = gdf.unary_union
...