GDAL / Python: Wie erhalte ich den Namen des Koordinatensystems von SpatialReference?

18

In Python habe ich mit GDAL die Projektion eines Rasters wie folgt als WKT-Zeichenfolge extrahiert:

wkt = dataset.GetProjection()
# wkt is 'PROJCS["GDA_1994_Transverse_Mercator",GEOGCS["GDA_1994",DATUM["GDA_1994",SPHEROID["GRS_1980",6378137,298.2572221010002],TOWGS84[0,0,0,0,0,0,0]],PRIMEM["Greenwich",0],UNIT["degree",0.0174532925199433]],PROJECTION["Transverse_Mercator"],PARAMETER["latitude_of_origin",0],PARAMETER["central_meridian",117],PARAMETER["scale_factor",0.9996],PARAMETER["false_easting",500000],PARAMETER["false_northing",10000000],UNIT["Meter",1]]'

Mit der WKT-Zeichenfolge kann ich eine SpatialReference-Instanz wie folgt erstellen:

src = osr.SpatialReference()
src.ImportFromWkt(wkt)

Das ist einfach peasy. Ich kann mehrere Parameter der Projektion srcwie die UTM-Zone usw. leicht genug extrahieren . Aber ich kann nicht herausfinden, wie man so etwas wie den Namen der Projektion extrahiert, dh "GDA_1994_Transverse_Mercator". Dies muss sicherlich möglich sein, aber die Python-API-Dokumentation kann genauso gut nicht für alle Verwendungszwecke vorhanden sein.

Wie extrahiere ich die Namen der Projektion und des geografischen Koordinatensystems?

hendra
quelle

Antworten:

46

Siehe das Lernprogramm zu OGR-Projektionen und die OGRSpatialReference- Klasse. Insbesondere die GetAttrValue- Methode.

Hier ist ein Beispiel.

from osgeo import gdal,osr
ds=gdal.Open(r'SOMERASTER.TIF')
prj=ds.GetProjection()
print prj

srs=osr.SpatialReference(wkt=prj)
if srs.IsProjected:
    print srs.GetAttrValue('projcs')
print srs.GetAttrValue('geogcs')

Für mein Raster wird folgendes gedruckt:

PROJCS["WGS 84 / UTM zone 55N",GEOGCS["WGS 84",DATUM["WGS_1984",SPHEROID["WGS 84",6378137,298.257223563,AUTHORITY["EPSG","7030"]],AUTHORITY["EPSG","6326"]],PRIMEM["Greenwich",0],UNIT["degree",0.0174532925199433],AUTHORITY["EPSG","4326"]],PROJECTION["Transverse_Mercator"],PARAMETER["latitude_of_origin",0],PARAMETER["central_meridian",147],PARAMETER["scale_factor",0.9996],PARAMETER["false_easting",500000],PARAMETER["false_northing",0],UNIT["metre",1,AUTHORITY["EPSG","9001"]],AUTHORITY["EPSG","32655"]]
'WGS 84 / UTM zone 55N'
'WGS 84'
user2856
quelle