Maison développement back-end Tutoriel Python tutoriel python gdal : géométrie et projection

tutoriel python gdal : géométrie et projection

Dec 24, 2016 pm 04:01 PM
gdal geometry

Créer un objet géométrique vide : ogr.Geometry

Les méthodes utilisées pour définir les différentes géométries sont différentes (point, ligne, polygone, etc)

Créer un nouveau point, Utiliser la méthode AddPoint(, , []). La coordonnée z est généralement omise et la valeur par défaut est 0

Par exemple :

point = ogr.Geometry(ogr.wkbPoint)

point.AddPoint(10, 20)

Nouvelle ligne

Utilisez AddPoint(, , []) pour ajouter des points

Utilisez SetPoint(< index> , , , []) Changer les coordonnées du point

Par exemple, le code suivant modifie les coordonnées du point 0 :

line = ogr.Geometry(ogr.wkbLineString)

line.AddPoint(10,10)

line.AddPoint(20,20)

line.SetPoint(0 ,30, 30) #(10,10) -> (30,30)

Comptez le nombre de tous les points

imprimer la ligne.GetPointCount()

Lire point 0 La coordonnée x et la coordonnée y

print line.GetX(0)

print line.GetY(0)

Pour créer un nouveau polygone, créez d'abord un nouveau anneau, puis Ajouter des anneaux aux objets polygonaux.

Comment créer une bague ? Créez d’abord un nouvel objet anneau, puis ajoutez-y des points un par un.

ring = ogr.Geometry(ogr.wkbLinearRing)

ring.AddPoint(0,0)

ring.AddPoint(100,0)

ring.AddPoint(100,100)

ring.AddPoint(0,100)

À la fin, utilisez CloseRings pour fermer l'anneau, ou définissez les coordonnées du dernier point pour qu'elles soient les mêmes que celles du premier indiquer.

ring.CloseRings()

ring.AddPoint(0,0)

Ce qui suit est un exemple pour créer une boîte. Il s'agit d'un objet polygonal composé de deux couches d'anneaux.

outring = ogr.Geometry(ogr.wkbLinearRing)

outring.AddPoint(0,0)

outring.AddPoint(100,0)

outring.AddPoint(100,100)

outring.AddPoint(0,100)

outring.AddPoint(0,0)

inring = ogr.Geometry(ogr.wkbLinearRing)inring = ogr.Geometry(ogr.wkbLinearRing)

inring.AddPoint(25,25)

inring.AddPoint(75,25)

inring.AddPoint(75,75)

inring.AddPoint(25,75)

inring.CloseRings()

polygon = ogr.Geometry(ogr.wkbPolygon)

polygon.AddGeometry (outring)

polygon.AddGeometry(inring)

Les trois dernières phrases sont plus importantes, c'est-à-dire créez d'abord un objet polygone, puis ajoutez l'anneau extérieur et l'anneau intérieur

La phrase suivante peut vous aider à compter le nombre d'anneaux que votre polygone peut avoir

imprimer polygon.GetGeometryCount()

Lire les anneaux du polygone, l'ordre d'index et les ajouter lors de la création du polygone. l'ordre des anneaux est le même

outring = polygon.GetGeometryRef(0)

inring = polygon.GetGeometryRef(1)

Créer une géométrie composite multi-géométrie

Par exemple, MultiPoint, MultiLineString, MultiPolygon

Utilisez AddGeometry pour ajouter des formes géométriques ordinaires aux formes géométriques composites, par exemple :

multipoint = ogr.Geometry(ogr.wkbMultiPoint)

point = ogr.Geometry(ogr.wkbPoint)point = ogr.Geometry(ogr.wkbPoint)

point.AddPoint(10,10)

multipoint.AddGeometry(point)

point.AddPoint(20,20)

multipoint.AddGeometry(point)

Lire la géométrie dans MultiGeometry La méthode est la même que la lecture de l'anneau de Polygon. a dit que Polygon Est une MultiGeometry intégrée.

Ne supprimez pas la géométrie d'une fonctionnalité existante, car cela ferait planter python

Vous ne pouvez supprimer que la géométrie créée lors de l'exécution du script, par exemple, créée manuellement ou automatiquement par appelant d'autres fonctions. Même si cette géométrie a été utilisée pour créer d'autres fonctionnalités, vous pouvez toujours la supprimer.

Par exemple : Polygon.Destroy()

Concernant les projections de projection, utilisez l'objet SpatialReference

Une variété de projections, GDAL prend en charge WKT, PROJ.4, ESPG, USGS, ESRI.prj

peut lire les projections de la couche et de la géométrie, par exemple :

spatialRef = layer.GetSpatialRef()

spatialRef = geom.GetSpatialReference()

Les informations de projection sont généralement stockées dans un fichier .prj. S'il n'existe pas de fichier de ce type, la fonction ci-dessus renvoie Aucun

Créez une nouvelle projection :

Importez d'abord la bibliothèque osr, puis utilisez osr.SpatialReference () Après avoir créé l'objet SpatialReference

, utilisez les instructions suivantes pour importer les informations de projection dans l'objet SpatialReference

•ImportFromWkt()

•ImportFromEPSG()

•ImportFromProj4()

•ImportFromESRI()

•ImportFromPCI( , ,

)

 •ImportFromUSGS(, )

•ImportFromXML()

Exporter la projection, utiliser Les instructions suivantes peuvent être exportées sous forme de chaînes

•ExportToWkt()

•ExportToPrettyWkt()

•ExportToProj4()

•ExportToPCI()

•ExportToUSGS()

•ExportToXML()

Pour effectuer une transformation de projection sur une forme géométrique Geometry, vous devez d'abord initialiser deux Projections, puis créer un objet CooperativeTransformation et l'utiliser pour la transformation

sourceSR = osr.SpatialReference()

sourceSR .ImportFromEPSG(32612) #UTM 12N WGS84

targetSR = osr.SpatialReference()

targetSR.ImportFromEPSG(4326) #Geo WGS84

coordTrans = osr.CoordonnéeTransformation(sourceSR , targetSR)

geom.Transform(coordTrans)

Mais ce code est très pénible ! Cela ne fonctionne pas sous Windows. Il y a une discussion sur le forum des étrangers, disant qu'il n'y a pas de problème sous Linux, mais que Windows est mort, hé. . .

Il y a quelques autres points auxquels il faut faire attention :

Modifiez la géométrie au moment approprié. Il est préférable de ne pas la déplacer après la transformation de la projection.

Pour effectuer une transformation de projection sur toute la géométrie d'une DataSource, vous devez le faire une par une. Utilisez une boucle.

Écrire votre projection dans un fichier .prj est en fait très simple. Tout d'abord, MorphToESRI(), convertissez-le en chaîne, puis ouvrez un fichier texte et écrivez-le dedans. Par exemple :

targetSR.MorphToESRI()

file = open('test.prj', 'w')

file.write(targetSR.ExportToWkt())

ffile.close()

Ce qui précède est le contenu du didacticiel python gdal : géométrie et projection. Pour plus de contenu connexe, veuillez faire attention au site Web PHP chinois (www.php. cn) !


Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn

Outils d'IA chauds

Undresser.AI Undress

Undresser.AI Undress

Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover

AI Clothes Remover

Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool

Undress AI Tool

Images de déshabillage gratuites

Clothoff.io

Clothoff.io

Dissolvant de vêtements AI

Video Face Swap

Video Face Swap

Échangez les visages dans n'importe quelle vidéo sans effort grâce à notre outil d'échange de visage AI entièrement gratuit !

Outils chauds

Bloc-notes++7.3.1

Bloc-notes++7.3.1

Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise

SublimeText3 version chinoise

Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1

Envoyer Studio 13.0.1

Puissant environnement de développement intégré PHP

Dreamweaver CS6

Dreamweaver CS6

Outils de développement Web visuel

SublimeText3 version Mac

SublimeText3 version Mac

Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Comment résoudre le problème des autorisations rencontré lors de la visualisation de la version Python dans le terminal Linux? Comment résoudre le problème des autorisations rencontré lors de la visualisation de la version Python dans le terminal Linux? Apr 01, 2025 pm 05:09 PM

Solution aux problèmes d'autorisation Lors de la visualisation de la version Python dans Linux Terminal Lorsque vous essayez d'afficher la version Python dans Linux Terminal, entrez Python ...

Comment enseigner les bases de la programmation novice en informatique dans le projet et les méthodes axées sur les problèmes dans les 10 heures? Comment enseigner les bases de la programmation novice en informatique dans le projet et les méthodes axées sur les problèmes dans les 10 heures? Apr 02, 2025 am 07:18 AM

Comment enseigner les bases de la programmation novice en informatique dans les 10 heures? Si vous n'avez que 10 heures pour enseigner à l'informatique novice des connaissances en programmation, que choisissez-vous d'enseigner ...

Comment éviter d'être détecté par le navigateur lors de l'utilisation de Fiddler partout pour la lecture de l'homme au milieu? Comment éviter d'être détecté par le navigateur lors de l'utilisation de Fiddler partout pour la lecture de l'homme au milieu? Apr 02, 2025 am 07:15 AM

Comment éviter d'être détecté lors de l'utilisation de FiddlereVerywhere pour les lectures d'homme dans le milieu lorsque vous utilisez FiddlereVerywhere ...

Comment copier efficacement la colonne entière d'une dataframe dans une autre dataframe avec différentes structures dans Python? Comment copier efficacement la colonne entière d'une dataframe dans une autre dataframe avec différentes structures dans Python? Apr 01, 2025 pm 11:15 PM

Lorsque vous utilisez la bibliothèque Pandas de Python, comment copier des colonnes entières entre deux frames de données avec différentes structures est un problème courant. Supposons que nous ayons deux dats ...

Comment Uvicorn écoute-t-il en permanence les demandes HTTP sans servir_forever ()? Comment Uvicorn écoute-t-il en permanence les demandes HTTP sans servir_forever ()? Apr 01, 2025 pm 10:51 PM

Comment Uvicorn écoute-t-il en permanence les demandes HTTP? Uvicorn est un serveur Web léger basé sur ASGI. L'une de ses fonctions principales est d'écouter les demandes HTTP et de procéder ...

Comment créer dynamiquement un objet via une chaîne et appeler ses méthodes dans Python? Comment créer dynamiquement un objet via une chaîne et appeler ses méthodes dans Python? Apr 01, 2025 pm 11:18 PM

Dans Python, comment créer dynamiquement un objet via une chaîne et appeler ses méthodes? Il s'agit d'une exigence de programmation courante, surtout si elle doit être configurée ou exécutée ...

See all articles