【发布时间】:2011-07-21 15:07:09
【问题描述】:
我尝试了以下方法, 输入:纬度/经度数据 然后我将计算它周围的一个框,比如说 50 m,所以东/北值是 +/- 50 m。
现在我将其重新转换为纬度/经度并使用脚本:
http://robotics.ai.uiuc.edu/~hyoon24/LatLongUTMconversion.py 我得到了一个不可能的结果,lon 之前是 7 左右,之后是 2 左右。
zone, easting, northing = LLtoUTM(23, location.get_lat(), location.get_lon())
topUTM = northing + error
bottomUTM = northing - error
leftUTM = easting - error
rightUTM = easting + error
left, top = UTMtoLL(23, leftUTM, topUTM, zone)
是我的代码有错误,还是脚本有缺陷?
所以我尝试使用 pyproj,只是 lat/lon 到 utm 到 lat/lon 看看会发生什么
>>> p = pyproj.Proj(proj='utm', zone=32, ellps='WGS84')
>>> p
<pyproj.Proj object at 0x7ff9b8487dd0>
>>> x,y = p(47.9941214, 7.8509671)
>>> print x,y
5159550.36822 1114087.43925
>>> print p(x,y,inverse=True)
(47.971558538495991, 7.8546573140162605)
在这里,它并没有像上面的脚本那么遥远,但它似乎仍然非常不正确,以至于无法使用它。怎么会?我该怎么做才能得到更准确的结果?
编辑:
我运行了 test() 并且所有测试都通过了。
在 epsg 文件中没有这样的东西。我找到的最接近的是:
<32632> +proj=utm +zone=32 +ellps=WGS84 +datum=WGS84 +units=m +no_defs <>
没有 tmerc。另外我需要什么将 towgs84 作为参数传递?上面那些?
【问题讨论】:
标签: python latitude-longitude utm