Obtener las coordenadas de línea o multilínea en QGIS a través de PyQGIS

Dec 03 2020

Podemos obtener coordenadas de capa de puntos a través del siguiente código, pero quiero saber las coordenadas de línea o multilínea. ¿Cómo conseguir estas coordenadas?

layer = QgsProject.instance().mapLayersByName("layerName")[0]
iter = layer.getFeatures()
for feature in iter:
  geom=feature.geometry()
  print(geom.asPoint().x(),geom.asPoint().y())

Respuestas

4 Zoltan Dec 03 2020 at 14:01

Para cadenas de líneas de varias partes, puede usar el siguiente código (lo probé en 3.16.1)

layer = QgsProject.instance().mapLayersByName("folyo")[0]
for feature in layer.getFeatures():
    for part in feature.geometry().asMultiPolyline():
        print("part")
        for pnt in part:
            print(pnt.x(), pnt.y())

Para cadenas de líneas de una sola parte:

layer = QgsProject.instance().mapLayersByName("Single parts")[0]
for feature in layer.getFeatures():
    for pnt in feature.geometry().asPolyline():
        print(pnt.x(), pnt.y())

asMultiPolyline y asPolyline devuelven una lista de puntos, por lo que puede utilizar índices.

ACTUALIZAR para comprobar el tipo de geometría de la capa, utilice el método geometryType de la capa. Para separar uno y varios tipos, utilice la función isSingleType. Aquí está el código para ello:

layer = QgsProject.instance().mapLayersByName("your_layer")[0]
if layer.geometryType() ==  QgsWkbTypes.LineGeometry:
    for feature in layer.getFeatures():
        geom = feature.geometry()
        if QgsWkbTypes.isSingleType(geom.wkbType()):
            # single
            for pnt in geom.asPolyline():
                print(pnt.x(), pnt.y())
        else:
            # multipart
            for part in geom.asMultiPolyline():
                print("part")
                for pnt in part:
                    print(pnt.x(), pnt.y())
2 ahmadhanb Dec 03 2020 at 14:03

Si desea extraer el xy de los vértices de una geometría MultiPolyline, puede usar el siguiente código:

layer = QgsProject.instance().mapLayersByName("layerName")[0]
iter = layer.getFeatures()
for feature in iter:
    geom=feature.geometry()
    verts = geom.asMultiPolyline() # use geom.asPolyline() for line geometry
    for vert in verts:
        for i in range(len(vert)):
            print(vert[i].x(),vert[i].y())

La salida será así

-3487202.783144876 10010395.30478035
-3428476.505393841 10049595.900699263
-3428476.505393841 10049595.900699263
-3374593.995628879 9923727.261801671
-3428476.505393841 10049595.900699263
-3359626.0983730364 10059037.052994486