Conociendo PyQGIS
Vanessa Penagos
data:image/s3,"s3://crabby-images/e63d3/e63d34ebc47efb4e5b668be8cbd438c3bfd4108e" alt=""
data:image/s3,"s3://crabby-images/19b06/19b069df6f2452d39284bdf6b1eae0dbeea11de3" alt=""
Somos una comunidad y semillero de investigación que busca generar el interés de las mujeres y niñas en la tecnología, generando espacios que promuevan su participación en este campo mediante el aprendizaje colectivo, compartiendo conocimientos y recursos técnicos con otras comunidades.
data:image/s3,"s3://crabby-images/d5234/d52348b0911618303aa6465b08328fb5e1e97f0a" alt=""
data:image/s3,"s3://crabby-images/d5234/d52348b0911618303aa6465b08328fb5e1e97f0a" alt=""
data:image/s3,"s3://crabby-images/5b3fb/5b3fb5497de86628229757d153e190f01af01805" alt=""
GIS
Sistemas de información geográfica
data:image/s3,"s3://crabby-images/d5234/d52348b0911618303aa6465b08328fb5e1e97f0a" alt=""
data:image/s3,"s3://crabby-images/ca80c/ca80c2c1131d7dab9867ad40a9757bdd0298b139" alt=""
- Ver datos
-
Explorar datos y diseñar mapas
-
Explorar datos y componer mapas
-
Analizar datos
-
Servicios Web
-
Funcionalidades GIS extendidas gracias a
complementos
-
Complementos externos Python
data:image/s3,"s3://crabby-images/1f844/1f844caa6edebcbb366fbfec45d6e89ca3c06716" alt=""
data:image/s3,"s3://crabby-images/d5234/d52348b0911618303aa6465b08328fb5e1e97f0a" alt=""
Ejecutar python en QGis
Directorio .qgis2/python
Archivo startup.py
- Archivo de inicio
- Consola de Python
data:image/s3,"s3://crabby-images/d72c5/d72c5116822bf1174b0e9ff789b5d4b7f1ee1625" alt=""
data:image/s3,"s3://crabby-images/d5234/d52348b0911618303aa6465b08328fb5e1e97f0a" alt=""
Cargar un proyecto
from qgis.core import QgsProject
project = QgsProject.instance()
print(project.fileName())
project.read('/home/user/projects/my_other_qgis_project.qgs')
print(project.fileName())
>>'/home/user/projects/my_other_qgis_project.qgs'
project.write()
project.write('/home/user/projects/my_new_qgis_project.qgs')
Modificar el proyecto
data:image/s3,"s3://crabby-images/d5234/d52348b0911618303aa6465b08328fb5e1e97f0a" alt=""
Capas
import os
from qgis.core import (
QgsVectorLayer
)
data:image/s3,"s3://crabby-images/d9226/d92269b5fbee0eeb6019bb84f54d8bc140164f8d" alt=""
- Capas vectoriales
- Capas Raster
data:image/s3,"s3://crabby-images/d5234/d52348b0911618303aa6465b08328fb5e1e97f0a" alt=""
Capas vectoriales
-
OGR
- PostGIS
- CSV
- GPX
- SpatiaLite database
- Las geometrias basadas en WKB de MySQL
- Conexión WFS
data:image/s3,"s3://crabby-images/d5234/d52348b0911618303aa6465b08328fb5e1e97f0a" alt=""
import os
from qgis.core import (QgsVectorLayer)
path_to_ports_layer = '/home/Escritorio/COL_adm/COL_adm1.shp'
colombia00 = QgsVectorLayer(path_to_ports_layer, "Col01", "ogr")
if not colombia00.isValid():
print("Error al cargar capa!")
QgsMapLayerRegistry.instance().addMapLayer(colombia00)
data:image/s3,"s3://crabby-images/2fa6f/2fa6faed2e31dda32d113a69718c898e6e676da2" alt=""
data:image/s3,"s3://crabby-images/d5234/d52348b0911618303aa6465b08328fb5e1e97f0a" alt=""
rlayer = QgsRasterLayer(path_to_tif, "SRTM layer name")
if not rlayer.isValid():
print("Layer failed to load!")
Capas Raster
data:image/s3,"s3://crabby-images/a4a94/a4a949454ea5293ec774fbe0c60ba1074752dd43" alt=""
data:image/s3,"s3://crabby-images/d5234/d52348b0911618303aa6465b08328fb5e1e97f0a" alt=""
from PyQt4.QtCore import *
path_layer = '/home/Escritorio/NE1_50M_SR_W/NE1_50M_SR_W.tif'
layer = QgsRasterLayer(path_layer, 'layer01')
QgsMapLayerRegistry.instance().addMapLayer(layer)
if not layer.isValid():
print("Layer failed to load!")
data:image/s3,"s3://crabby-images/621ca/621ca5c1b2e548381c53a4ecd9c6c973343ce531" alt=""
data:image/s3,"s3://crabby-images/d5234/d52348b0911618303aa6465b08328fb5e1e97f0a" alt=""
Operaciones sobre capas vectoriales
layers = QgsMapLayerRegistry.instance().mapLayers()
for name, layer in layers.iteritems():
if layer.geometryType() == QGis.Point:
print("Point")
if layer.geometryType() == QGis.Line:
print("Line")
if layer.geometryType() == QGis.Polygon:
print("Polygon")
Iterar sobre una capa vectorial
data:image/s3,"s3://crabby-images/48791/48791e9cd2db02a7a36ff59fd8af4905d0846cb2" alt=""
QgsMapLayerRegistry.instance().addMapLayer(layer)
QgsMapLayerRegistry.instance().removeMapLayer(layer_id)
QgsMapLayerRegistry.instance().mapLayers()
data:image/s3,"s3://crabby-images/d5234/d52348b0911618303aa6465b08328fb5e1e97f0a" alt=""
Selección de objetos espaciales
iface.mapCanvas().setSelectionColor(QColor("red"))
layer = iface.activeLayer()
layer.selectByExpression(u'"ID_1" > 10', QgsVectorLayer.SetSelection)
selected_fid = []
for feature in layer.getFeatures():
selected_fid.append(feature.id())
break
layer.select(selected_fid)
layer.removeSelection()
Agregar entidades
Limpiar la selección
data:image/s3,"s3://crabby-images/de330/de330ecdeaa4f8131d56ef0994225dfb5c990f8f" alt=""
selection = layer.selectedFeatures()
print(len(selection))
for feature in selection:
...
data:image/s3,"s3://crabby-images/d5234/d52348b0911618303aa6465b08328fb5e1e97f0a" alt=""
-
Agregar nuevas entidades
-
Eliminar entidades
-
Modificar entidades existentes
-
Cambiar valores de atributos
caps = layer.dataProvider().capabilities()
caps_string = layer.dataProvider().capabilitiesString()
QgsVectorDataProvider.AddFeatures
QgsVectorDataProvider.DeleteFeatures
QgsVectorDataProvider.ChangeAttributeValues
QgsVectorDataProvider.ChangeGeometries
- Añadir atributos
-
Cambiar nombre de atriburos
-
Crear indices espaciales y de atributo
-
Acceso rapido mediante ID
-
Cambiar geometrias
data:image/s3,"s3://crabby-images/d5234/d52348b0911618303aa6465b08328fb5e1e97f0a" alt=""
if caps & QgsVectorDataProvider.AddFeatures:
feat = QgsFeature(layer.pendingFields())
feat.setAttributes([0, 'hello'])
feat.setAttribute('name', 'hello')
feat.setAttribute(0, 'hello')
feat.setGeometry(QgsGeometry.fromPoint(QgsPoint(123, 456)))
(res, outFeats) = layer.dataProvider().addFeatures([feat])
if caps & QgsVectorDataProvider.DeleteFeatures:
res = layer.dataProvider().deleteFeatures([5, 10])
Añadir y eliminar
objetos espaciales
data:image/s3,"s3://crabby-images/d5234/d52348b0911618303aa6465b08328fb5e1e97f0a" alt=""
from PyQt4.QtCore import QVariant
if caps & QgsVectorDataProvider.AddAttributes:
res = layer.dataProvider().addAttributes(
[QgsField("mytext", QVariant.String),
QgsField("myint", QVariant.Int)])
if caps & QgsVectorDataProvider.DeleteAttributes:
res = layer.dataProvider().deleteAttributes([0])
layer.updateFields()
Añadir y eliminar
atributos
data:image/s3,"s3://crabby-images/d5234/d52348b0911618303aa6465b08328fb5e1e97f0a" alt=""
layer=iface.activeLayer()
if layer.isEditable():
inlayer.startEditing()
# ...
inlayer.commitChanges()
inlayer.rollBack()
#----------------------------------
beginEditCommand()
endEditCommand())
destroyEditCommand()
Modo edición
data:image/s3,"s3://crabby-images/397c8/397c8db0830e7a0dc73a2d016a6f329580dd89e3" alt=""
data:image/s3,"s3://crabby-images/d5234/d52348b0911618303aa6465b08328fb5e1e97f0a" alt=""
index = QgsSpatialIndex()
index.insertFeature(feat)
index = QgsSpatialIndex(layer.getFeatures())
Indices espaciales
data:image/s3,"s3://crabby-images/7f131/7f1312aab2dc722240399fa61e4617d7865e7b9d" alt=""
data:image/s3,"s3://crabby-images/d5234/d52348b0911618303aa6465b08328fb5e1e97f0a" alt=""
Geometría
gPnt = QgsGeometry.fromPointXY(QgsPointXY(1,1))
gLine = QgsGeometry.fromPolyline([QgsPoint(1, 1), QgsPoint(2, 2)])
gPolygon = QgsGeometry.fromPolygonXY([[QgsPointXY(1, 1),
QgsPointXY(2, 2), QgsPointXY(2, 1)]])
data:image/s3,"s3://crabby-images/f6ba1/f6ba1e781f5533997276c1e74e9948d0d4ca5a0a" alt=""
data:image/s3,"s3://crabby-images/d5234/d52348b0911618303aa6465b08328fb5e1e97f0a" alt=""
for f in features:
geom = f.geometry()
print('Area: ', geom.area())
print('Perimetro: ', geom.length())
..
d = QgsDistanceArea()
d.setEllipsoid('WGS84')
d.setEllipsoidalMode(True)
print "Distancia en metros: ", d.measureLine(QgsPoint(x1,y1),QgsPoint(x2,y2))
data:image/s3,"s3://crabby-images/4086c/4086cbbcd9ee4f958d90c08e573436ddf9466d55" alt=""
- Transformación geométrica: Reproject algorithm
- Distancia y Area usando QgsDistanceArea: Distance matrix algorithm
- Multi-part to single-part algorithm
data:image/s3,"s3://crabby-images/d5234/d52348b0911618303aa6465b08328fb5e1e97f0a" alt=""
Lienzo de Mapa
canvas = QgsMapCanvas()
canvas.show()
# Añadir capas al lienzo
canvas.setExtent(layer.extent())
canvas.setLayerSet([QgsMapCanvasLayer(layer)])
canvas.scene().removeItem(element)
data:image/s3,"s3://crabby-images/c0b98/c0b984e04c88248eb1bb917cd8b4d060860aefcd" alt=""
-
setMapTool()
-
QgsMapToolPan
-
QgsMapToolZoom
-
QgsRubberBand
-
QgsVertexMarke
data:image/s3,"s3://crabby-images/d5234/d52348b0911618303aa6465b08328fb5e1e97f0a" alt=""
Subestaciones eleléctricas
data:image/s3,"s3://crabby-images/7ed17/7ed17c3569a112c39e44ab1760ba6e67b4d98818" alt=""
data:image/s3,"s3://crabby-images/e7ec8/e7ec8f563f699326125155e9677730201a1efbdb" alt=""
Un ejemplo
data:image/s3,"s3://crabby-images/d5234/d52348b0911618303aa6465b08328fb5e1e97f0a" alt=""
Otras cosas...
- Manejo de expresiones
- Manejo de errores
- Sistemas de cordenadas de referencia
- Renderizar mapa
- Configuración de lectura y almacenamiento
- Comunicación con usuario
data:image/s3,"s3://crabby-images/e602e/e602eccd71cb26e8817b2747b6aee272eab8b12e" alt=""
data:image/s3,"s3://crabby-images/d5234/d52348b0911618303aa6465b08328fb5e1e97f0a" alt=""
Fuentes de datos
- 1. Natural Earth
- 2. OpenStreetMap
- 3. Geofabrik
- 4. DIVA-GIS
- 5. GADM
- 6. EuroGlobalMap
- 7. Global Map
- 8. OpenAerialMap
- 9. UNEP GEOData
- 10. Global Climate Monitor
- 11. Centro de Descargas del IGN
- 12. Servicio de Cartografía Digital e Infraestructura de Datos Espaciales de la Universidad de Extremadura
- 13. Infraestructura de Datos Espaciales de las Naciones Unidas (UNSDI_NCO GeoNetwork Portal)
data:image/s3,"s3://crabby-images/d5234/d52348b0911618303aa6465b08328fb5e1e97f0a" alt=""
data:image/s3,"s3://crabby-images/ddd6d/ddd6d2196695d0a79d1bec0fac808e94dba234bb" alt=""
data:image/s3,"s3://crabby-images/d5234/d52348b0911618303aa6465b08328fb5e1e97f0a" alt=""
¡Gracias!
data:image/s3,"s3://crabby-images/0fac5/0fac58940c72ff8a3c0e79cdbf8b0c17826e3260" alt=""
data:image/s3,"s3://crabby-images/d5234/d52348b0911618303aa6465b08328fb5e1e97f0a" alt=""
- https://docs.qgis.org
- https://mappinggis.com/2012/05/datos-cartograficos/
webgrafia
data:image/s3,"s3://crabby-images/7a5f2/7a5f2644f6a6555388839ca9686d96f3e5458e06" alt=""
PyQGIS
By Vanessa Penagos
PyQGIS
- 734