如何在Python中计算多边形的重心
我在想有没有什么算法可以用来计算OSM中多边形的中心,因为我发现每个多边形的参数表达式都不一样:
"POLYGON((-171379.35 5388068.23,-171378.8 5388077.59,-171368.44 5388076.82,-171368.89 5388067.46,-171379.35 5388068.23))"
"POLYGON((-171379.3 5374226.42,-171375.96 5374227.32,-171378.95 5374239.82,-171365.69 5374243.03,-171364.16 5374237.14,-171365.92 5374236.76,-171364.26 5374230.26,-171362.67 5374230.63,-171360.11 5374220.19,-171376.6 5374216.13,-171379.3 5374226.42))"
在这个表达式中,每个多边形的参数数量都不同,那我该怎么计算它的中心点呢?
我正在使用postgis来获取空间信息中的多边形数据。
2 个回答
1
你可以使用PostGIS的功能,或者使用一个叫shapely的Python库来实现这个功能。
11
这些多边形是用一种叫做 WKT 的格式来描述的。
如果你在用Python编程,可以使用 Shapely 这个库。
from shapely import wkt
p1 = wkt.loads("POLYGON((-171379.35 5388068.23,-171378.8 5388077.59,
-171368.44 5388076.82,-171368.89 5388067.46,
-171379.35 5388068.23))")
p2 = wkt.loads("POLYGON((-171379.3 5374226.42,-171375.96 5374227.32,
-171378.95 5374239.82,-171365.69 5374243.03,
-171364.16 5374237.14,-171365.92 5374236.76,
-171364.26 5374230.26,-171362.67 5374230.63,
-171360.11 5374220.19,-171376.6 5374216.13,
-171379.3 5374226.42))")
print(p1.centroid.wkt) # POINT (-171373.8710815240337979 5388072.5175872016698122)
print(p2.centroid.wkt) # POINT (-171370.4190352254081517 5374229.0108996396884322)