¿Cuál es la mejor manera de convertir mediante programación entre cadenas WKT y Proj4?

13

Algunos shapefiles tienen un archivo .prj asociado, y el archivo .prj contiene la información de proyección del shapefile en el formato WKT. A veces necesito convertir WKT a una cadena de proj4, y otras veces necesito volver a convertirla.

¿Hay alguna biblioteca preparada para hacer esto?

    
pregunta Cui Pengfei 崔鹏飞 14.04.2011 - 18:04

4 respuestas

11

La parte de referencia espacial OGR de GDAL debería hacer el truco. Capooti proporcionó una excelente respuesta a otra pregunta lo que demuestra cómo realizar la traducción de un shapefile a WKT. También puede consultar la referencia de clase . Lo contrario es simplemente:

from osgeo import osr

srs = osr.SpatialReference()
wkt_text = 'GEOGCS["GCS_WGS_1984",DATUM["WGS_1984",' \
           'SPHEROID["WGS_1984",6378137,298.257223563]],PRIMEM["Greenwich",0],'\
           'UNIT["Degree",0.017453292519943295]]'
# Imports WKT to Spatial Reference Object
srs.ImportFromWkt(wkt_text)
srs.MorphToESRI() # converts the WKT to an ESRI-compatible format
print "ESRI compatible WKT for use as .prj:" % srs.ExportToWkt()
    
respondido por el scw 14.04.2011 - 18:47
2

También puede utilizar PyCRS :

import pycrs

print(pycrs.parser.from_esri_wkt(wkt_text).to_proj4())
# +proj=longlat +ellps=WGS84 +a=6378137.0 +f=298.257223563 +pm=0.0  +no_defs
    
respondido por el astrojuanlu 23.06.2017 - 10:22
1

No conozco ninguna biblioteca, pero puede usar este sitio para obtener las traducciones: enlace

EDITAR: Encontré una secuencia de comandos de python que funciona con ogr python bindings para hacer eso. Aquí está .

    
respondido por el Pablo 14.04.2011 - 18:08
0

Necesito transformar de forma pragramática a una proyección personalizada basada en la cadena proj4text, por lo que se usa

projection = '+proj=lcc +lat_1=53 +lat_2=70 +lat_0=0 +lon_0=136 +x_0=0 +y_0=0 +ellps=intl +units=m +no_defs'

source = osr.SpatialReference() source.ImportFromEPSG(4326) target = osr.SpatialReference() target.ImportFromProj4(projection) transform = osr.CoordinateTransformation(source, target)

    
respondido por el Jane 03.07.2018 - 12:19

Lea otras preguntas en las etiquetas