如何将 HEXEWKB 转换为纬度、经度 (in python)?
How to convert HEXEWKB to Latitude, Longitude (in python)?
我从 OpenStreetMap 下载了一些兴趣点数据,结果发现这些位置是以 HEXEWKB 格式编码的:
CSV fields
==============================================
1 : Node type; N|W|R (in upper case), wheter it is a Node, Way or Relation in the openstreetmap model
2 : id; The openstreetmap id
3 : name; The default name of the city
4 : countrycode; The iso3166-2 country code (2 letters)
5 : alternatenames; the names of the POI in other languages
6 : location; The middle location of the POI in HEXEWKB
7 : tags; the POI tags : amenity,aeroway,building,craft,historic,leisure,man_made,office,railway,tourism,shop,sport,landuse,highway separated by '___'
我需要将它们转换成 longitude/latitude 值。之前针对 Java 语言 (How to convert HEXEWKB to Latitude, Longitude (in java)?) 提出过同样的问题,但是我需要一个 Python 解决方案。
到目前为止,我的尝试一直集中在尝试使用 GeoDjango 的 GEOS 模块 (https://docs.djangoproject.com/en/1.8/ref/contrib/gis/geos/#creating-a-geometry),但由于我没有在我的应用程序中使用 Django,这感觉有点过头了。有没有更简单的方法?
在尝试不同的库后,我在一个有点相关的问题中找到了最实用的解决方案:. This involves using shapely (https://pypi.python.org/pypi/Shapely):
from shapely import wkb
hexlocation = "0101000020E6100000CB752BC86AC8ED3FF232E58BDA7E4440"
point = wkb.loads(hexlocation, hex=True)
longitude = point.x
latitude = point.y
也就是说,你只需要使用 wkb.loads 将 HEXEWKB 字符串转换为一个 shapely Point 对象,然后从中提取 long/lat 坐标点.
我从 OpenStreetMap 下载了一些兴趣点数据,结果发现这些位置是以 HEXEWKB 格式编码的:
CSV fields
==============================================
1 : Node type; N|W|R (in upper case), wheter it is a Node, Way or Relation in the openstreetmap model
2 : id; The openstreetmap id
3 : name; The default name of the city
4 : countrycode; The iso3166-2 country code (2 letters)
5 : alternatenames; the names of the POI in other languages
6 : location; The middle location of the POI in HEXEWKB
7 : tags; the POI tags : amenity,aeroway,building,craft,historic,leisure,man_made,office,railway,tourism,shop,sport,landuse,highway separated by '___'
我需要将它们转换成 longitude/latitude 值。之前针对 Java 语言 (How to convert HEXEWKB to Latitude, Longitude (in java)?) 提出过同样的问题,但是我需要一个 Python 解决方案。
到目前为止,我的尝试一直集中在尝试使用 GeoDjango 的 GEOS 模块 (https://docs.djangoproject.com/en/1.8/ref/contrib/gis/geos/#creating-a-geometry),但由于我没有在我的应用程序中使用 Django,这感觉有点过头了。有没有更简单的方法?
在尝试不同的库后,我在一个有点相关的问题中找到了最实用的解决方案:
from shapely import wkb
hexlocation = "0101000020E6100000CB752BC86AC8ED3FF232E58BDA7E4440"
point = wkb.loads(hexlocation, hex=True)
longitude = point.x
latitude = point.y
也就是说,你只需要使用 wkb.loads 将 HEXEWKB 字符串转换为一个 shapely Point 对象,然后从中提取 long/lat 坐标点.