怎么在Python中计算多边形的质心

本教程将介绍如何在Python中计算多边形的质心的处理方法,这篇教程是从别的地方看到的,然后加了一些国外程序员的疑问与解答,希望能对你有所帮助,好了,下面开始学习吧。

怎么在Python中计算多边形的质心 教程 第1张

问题描述

我想知道在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从空间信息中获取多边形信息。

推荐答案

使用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)

好了关于怎么在Python中计算多边形的质心的教程就到这里就结束了,希望趣模板源码网找到的这篇技术文章能帮助到大家,更多技术教程可以在站内搜索。