Геопанда цвет близких фигур того же цвета - PullRequest
0 голосов
/ 31 января 2019

У меня есть файл геопанды с более чем 100 полигонами, и разреженный набор (~ 10 из которых) имеет интересующее значение.Есть ли простой способ присвоить оставшимся 90+ полигонам значение, основанное на значении ближайшего ненулевого полигона?

Заранее спасибо

1 Ответ

0 голосов
/ 04 февраля 2019

Приведенный ниже код указывает алгоритм, который соединяет многоугольники с «нулевым значением» с ближайшими многоугольниками с допустимым значением, используя пространственное соединение (ближайший сосед) на основе их центроидов.

Обратите внимание на кодчерновик кода, который вам нужен;это указывает на общий алгоритм, но вам нужно завершить функции на основе ваших данных и ваших переменных.

# gdf with all the polygons
gdf1 = gpd.read_file(...)

# calculate a column with the centroid geometry; 
# it will be used later.
# note: this is not the active gdf geometry at this stage
gdf1['geometry_pt'] = gdf1['geometry'].centroid

# set the point geometry as the active geometry
gdf1.set_geometry('geometry_pt')

# filter out the gdf in two gdfs, with/without the value you want
gdf1_yesval = gdf1.loc[gdf1['field1'] != 0]
gdf1_noval  = gdf1.loc[gdf1['field1'] == 0]

# perform a spatial join to assign the closest value to the points with no value
# for this, apply the code in the link below
gdf1_noval_joined = gdf1_noval.apply(...  nearest... gdf1_yesval... )

# do the necessary column operations in the joined gdf 
# to update your desired columns with values from the spatially joined gdf
gdf1_noval_joined['field1'] = gdf1_noval_joined['joinedfieldA']

# delete the unnecessary columns in the joined gdf
gdf1_noval_joined.drop(columns=['joinedfieldA', 'joinedfieldB'], inplace=True)

# concatenate the two gdfs to make one
df2 = pd.concat([gdf1_yesval, gdf1_noval_joined])

# convert it into a gdf again
gdf2 = gpd.GeoDataFrame(df2, geometry='geometry')

Ссылка, где объясняется функция соединения с ближайшим соседом: https://gis.stackexchange.com/q/222315/93912

Надеюсь, это поможет.

...