mirror of
				https://github.com/qgis/QGIS.git
				synced 2025-10-30 00:07:09 -04:00 
			
		
		
		
	
		
			
				
	
	
		
			159 lines
		
	
	
		
			6.7 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
			
		
		
	
	
			159 lines
		
	
	
		
			6.7 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
| # -*- coding: utf-8 -*-
 | |
| 
 | |
| """
 | |
| ***************************************************************************
 | |
|     ImportIntoPostGIS.py
 | |
|     ---------------------
 | |
|     Date                 : October 2012
 | |
|     Copyright            : (C) 2012 by Victor Olaya
 | |
|     Email                : volayaf at gmail dot com
 | |
| ***************************************************************************
 | |
| *                                                                         *
 | |
| *   This program is free software; you can redistribute it and/or modify  *
 | |
| *   it under the terms of the GNU General Public License as published by  *
 | |
| *   the Free Software Foundation; either version 2 of the License, or     *
 | |
| *   (at your option) any later version.                                   *
 | |
| *                                                                         *
 | |
| ***************************************************************************
 | |
| """
 | |
| 
 | |
| __author__ = 'Victor Olaya'
 | |
| __date__ = 'October 2012'
 | |
| __copyright__ = '(C) 2012, Victor Olaya'
 | |
| 
 | |
| # This will get replaced with a git SHA1 when you do a git archive
 | |
| 
 | |
| __revision__ = '$Format:%H$'
 | |
| 
 | |
| from qgis.PyQt.QtCore import QSettings
 | |
| from qgis.core import QgsDataSourceUri, QgsVectorLayerImport
 | |
| 
 | |
| from processing.core.GeoAlgorithm import GeoAlgorithm
 | |
| from processing.core.GeoAlgorithmExecutionException import GeoAlgorithmExecutionException
 | |
| from processing.core.parameters import ParameterBoolean
 | |
| from processing.core.parameters import ParameterVector
 | |
| from processing.core.parameters import ParameterString
 | |
| from processing.core.parameters import ParameterSelection
 | |
| from processing.core.parameters import ParameterTableField
 | |
| from processing.tools import dataobjects, postgis
 | |
| 
 | |
| 
 | |
| class ImportIntoPostGIS(GeoAlgorithm):
 | |
| 
 | |
|     DATABASE = 'DATABASE'
 | |
|     TABLENAME = 'TABLENAME'
 | |
|     SCHEMA = 'SCHEMA'
 | |
|     INPUT = 'INPUT'
 | |
|     OVERWRITE = 'OVERWRITE'
 | |
|     CREATEINDEX = 'CREATEINDEX'
 | |
|     GEOMETRY_COLUMN = 'GEOMETRY_COLUMN'
 | |
|     LOWERCASE_NAMES = 'LOWERCASE_NAMES'
 | |
|     DROP_STRING_LENGTH = 'DROP_STRING_LENGTH'
 | |
|     FORCE_SINGLEPART = 'FORCE_SINGLEPART'
 | |
|     PRIMARY_KEY = 'PRIMARY_KEY'
 | |
|     ENCODING = 'ENCODING'
 | |
| 
 | |
|     def defineCharacteristics(self):
 | |
|         self.name, self.i18n_name = self.trAlgorithm('Import into PostGIS')
 | |
|         self.group, self.i18n_group = self.trAlgorithm('Database')
 | |
|         self.addParameter(ParameterVector(self.INPUT,
 | |
|                                           self.tr('Layer to import')))
 | |
| 
 | |
|         self.DB_CONNECTIONS = self.dbConnectionNames()
 | |
|         self.addParameter(ParameterSelection(self.DATABASE,
 | |
|                                              self.tr('Database (connection name)'), self.DB_CONNECTIONS))
 | |
|         self.addParameter(ParameterString(self.SCHEMA,
 | |
|                                           self.tr('Schema (schema name)'), 'public'))
 | |
|         self.addParameter(ParameterString(self.TABLENAME,
 | |
|                                           self.tr('Table to import to (leave blank to use layer name)'), optional=True))
 | |
|         self.addParameter(ParameterTableField(self.PRIMARY_KEY,
 | |
|                                               self.tr('Primary key field'), self.INPUT, optional=True))
 | |
|         self.addParameter(ParameterString(self.GEOMETRY_COLUMN,
 | |
|                                           self.tr('Geometry column'), 'geom'))
 | |
|         self.addParameter(ParameterString(self.ENCODING,
 | |
|                                           self.tr('Encoding'), 'UTF-8',
 | |
|                                           optional=True))
 | |
|         self.addParameter(ParameterBoolean(self.OVERWRITE,
 | |
|                                            self.tr('Overwrite'), True))
 | |
|         self.addParameter(ParameterBoolean(self.CREATEINDEX,
 | |
|                                            self.tr('Create spatial index'), True))
 | |
|         self.addParameter(ParameterBoolean(self.LOWERCASE_NAMES,
 | |
|                                            self.tr('Convert field names to lowercase'), True))
 | |
|         self.addParameter(ParameterBoolean(self.DROP_STRING_LENGTH,
 | |
|                                            self.tr('Drop length constraints on character fields'), False))
 | |
|         self.addParameter(ParameterBoolean(self.FORCE_SINGLEPART,
 | |
|                                            self.tr('Create single-part geometries instead of multi-part'), False))
 | |
| 
 | |
|     def processAlgorithm(self, progress):
 | |
|         connection = self.DB_CONNECTIONS[self.getParameterValue(self.DATABASE)]
 | |
|         db = postgis.GeoDB.from_name(connection)
 | |
| 
 | |
|         schema = self.getParameterValue(self.SCHEMA)
 | |
|         overwrite = self.getParameterValue(self.OVERWRITE)
 | |
|         createIndex = self.getParameterValue(self.CREATEINDEX)
 | |
|         convertLowerCase = self.getParameterValue(self.LOWERCASE_NAMES)
 | |
|         dropStringLength = self.getParameterValue(self.DROP_STRING_LENGTH)
 | |
|         forceSinglePart = self.getParameterValue(self.FORCE_SINGLEPART)
 | |
|         primaryKeyField = self.getParameterValue(self.PRIMARY_KEY) or 'id'
 | |
|         encoding = self.getParameterValue(self.ENCODING)
 | |
| 
 | |
|         layerUri = self.getParameterValue(self.INPUT)
 | |
|         layer = dataobjects.getObjectFromUri(layerUri)
 | |
| 
 | |
|         table = self.getParameterValue(self.TABLENAME)
 | |
|         if table:
 | |
|             table.strip()
 | |
|         if not table or table == '':
 | |
|             table = layer.name()
 | |
|             table = table.replace('.', '_')
 | |
|         table = table.replace(' ', '').lower()[0:62]
 | |
|         providerName = 'postgres'
 | |
| 
 | |
|         geomColumn = self.getParameterValue(self.GEOMETRY_COLUMN)
 | |
|         if not geomColumn:
 | |
|             geomColumn = 'the_geom'
 | |
| 
 | |
|         options = {}
 | |
|         if overwrite:
 | |
|             options['overwrite'] = True
 | |
|         if convertLowerCase:
 | |
|             options['lowercaseFieldNames'] = True
 | |
|             geomColumn = geomColumn.lower()
 | |
|         if dropStringLength:
 | |
|             options['dropStringConstraints'] = True
 | |
|         if forceSinglePart:
 | |
|             options['forceSinglePartGeometryType'] = True
 | |
| 
 | |
|         # Clear geometry column for non-geometry tables
 | |
|         if not layer.hasGeometryType():
 | |
|             geomColumn = None
 | |
| 
 | |
|         uri = db.uri
 | |
|         uri.setDataSource(schema, table, geomColumn, '', primaryKeyField)
 | |
| 
 | |
|         if encoding:
 | |
|             layer.setProviderEncoding(encoding)
 | |
| 
 | |
|         (ret, errMsg) = QgsVectorLayerImport.importLayer(
 | |
|             layer,
 | |
|             uri.uri(),
 | |
|             providerName,
 | |
|             self.crs,
 | |
|             False,
 | |
|             False,
 | |
|             options,
 | |
|         )
 | |
|         if ret != 0:
 | |
|             raise GeoAlgorithmExecutionException(
 | |
|                 self.tr('Error importing to PostGIS\n%s' % errMsg))
 | |
| 
 | |
|         if geomColumn and createIndex:
 | |
|             db.create_spatial_index(table, schema, geomColumn)
 | |
| 
 | |
|         db.vacuum_analyze(table, schema)
 | |
| 
 | |
|     def dbConnectionNames(self):
 | |
|         settings = QSettings()
 | |
|         settings.beginGroup('/PostgreSQL/connections/')
 | |
|         return settings.childGroups()
 |