我在“NAD 1983 StatePlane Michigan South FIPS 2113 Feet”(又名ESRI 102690)中有一个大的x,y坐标数据集。我想把它们转换成lat-lng点。
从理论上讲,这是proj可以处理的内容,但文档并没有给我一些线索 - 它似乎描述了更为复杂的案例。
我尝试使用python interface,如下所示:
from pyproj import Proj
p = Proj(init='esri:102690')
sx = 13304147.06410000000 #sample points
sy = 288651.94040000000
x2, y2 = p(sx, sy, inverse=True)
但是这会产生非常不正确的输出。
有一个Javascript库,但我有大约50,000个点要处理,所以这似乎不合适。
对我有用的是什么:
我创建了一个名为ptest
的文件,每对都在自己的行上,x和y坐标用空格分隔,如下所示:
13304147.06410000000 288651.94040000000
...
然后我将该文件输入命令并将结果传送到输出文件:
$>cs2cs -f %.16f +proj=lcc +lat_1=42.1 +lat_2=43.66666666666666
+lat_0=41.5 +lon_0=-84.36666666666666 +x_0=4000000 +y_0=0 +ellps=GRS80
+datum=NAD83 +to_meter=0.3048006096012192 +no_defs +zone=20N +to
+proj=latlon ptest > out.txt
答案 0 :(得分:4)
如果您只需要重新投影并可以对文本文件进行一些数据挖掘,请使用您喜欢的任何内容并使用http://spatialreference.org/ref/esri/102690/作为参考。
例如,使用Proj4并将其存储在shell / cmd文件中并使用proj4调用输入文件(linux / windows版本可用),数据集大小没问题。
cs2cs +proj=latlong +datum=NAD83 +to +proj=utm +zone=10 +datum=NAD27 -r <<EOF
cs2cs -f %.16f +proj=utm +zone=20N +to +proj=latlon - | awk '{print $1 " " $2}
所以在你的情况下是这样的:
cs2cs -f %.16f +proj=lcc +lat_1=42.1 +lat_2=43.66666666666666 +lat_0=41.5 +lon_0=-84.36666666666666 +x_0=4000000 +y_0=0 +ellps=GRS80 +datum=NAD83 +to_meter=0.3048006096012192 +no_defs +zone=20N +to +proj=latlon
答案 1 :(得分:3)
如果您有TXT,CSV或XLS文件中的坐标,您可以执行CTRL + C并将它们插入http://cs2cs.mygeodata.eu,您可以在其中设置适当的输入和所需的输出坐标系。可以以各种格式插入数千个坐标......