24.2.8. Vector miscellaneous
24.2.8.1. Build virtual vector
Creates a virtual vector layer that contains a set of vector layers.
This algorithm is especially useful in case another algorithm needs
multiple layers but accept only one vrt in which the layers are
specified.
Parameters
| Label | Name | Type | Description | 
|---|---|---|---|
| Input datasources | 
 | [vector: any] [list] | Select the vector layers you want to use to build the virtual vector | 
| Create “unioned” VRT | 
 | [boolean] Default: False | Check if you want to unite all the vectors in a
single  | 
| Virtual vector | 
 | [same as input] Default:  | Specify the output layer containing only the duplicates. One of: 
 | 
Outputs
| Label | Name | Type | Description | 
|---|---|---|---|
| Virtual vector | 
 | [vector: any] | The output virtual vector made from the chosen sources | 
Python code
Algorithm ID: gdal:buildvirtualvector
import processing
processing.run("algorithm_id", {parameter_dictionary})
The algorithm id is displayed when you hover over the algorithm in the Processing Toolbox. The parameter dictionary provides the parameter NAMEs and values. See Using processing algorithms from the console for details on how to run processing algorithms from the Python console.
24.2.8.2. Execute SQL
Runs a simple or complex query with SQL syntax on the source layer. The result of the query will be added as a new layer.
This algorithm is derived from the GDAL ogr2ogr utility.
Parameters
Basic parameters
| Label | Name | Type | Description | 
|---|---|---|---|
| Input layer | 
 | [vector: any] | OGR-supported input vector layer | 
| SQL expression | 
 | [string] | Defines the SQL query, for example
 | 
| SQL dialect | 
 | [enumeration] Default: 0 | SQL dialect to use. One of: 
 | 
| SQL result | 
 | [vector: any] | Specification of the output layer. One of: 
 For  | 
Advanced parameters
| Label | Name | Type | Description | 
|---|---|---|---|
| Additional creation options Optional | 
 | [string] Default: ‘’ (no additional options) | Additional GDAL creation options. | 
Outputs
| Label | Name | Type | Description | 
|---|---|---|---|
| SQL result | 
 | [vector: any] | Vector layer created by the query | 
Python code
Algorithm ID: gdal:executesql
import processing
processing.run("algorithm_id", {parameter_dictionary})
The algorithm id is displayed when you hover over the algorithm in the Processing Toolbox. The parameter dictionary provides the parameter NAMEs and values. See Using processing algorithms from the console for details on how to run processing algorithms from the Python console.
24.2.8.3. Export to PostgreSQL (available connections)
Imports vector layers inside a PostgreSQL database on the basis of an available connection. The connection has to be defined properly beforehand. Be aware that the checkboxes ‘Save Username’ and ‘Save Password’ are activated. Then you can use the algorithm.
This algorithm is derived from the GDAL ogr2ogr utility.
Parameters
| Label | Name | Type | Description | 
|---|---|---|---|
| Database (connection name) | 
 | [string] | The PostgreSQL database to connect to | 
| Input layer | 
 | [vector: any] | OGR-supported vector layer to export to the database | 
| Shape encoding Optional | 
 | [string] Default: ‘’ | Sets the encoding to apply to the data | 
| Output geometry type | 
 | [enumeration] Default: 0 | Defines the output geometry type. One of: 
 | 
| Assign an output CRS Optional | 
 | [crs] Default: Not set | Defines the output CRS of the database table | 
| Reproject to this CRS on output Optional | 
 | [crs] Default: Not set | Reprojects/transforms to this CRS on output | 
| Override source CRS Optional | 
 | [crs] Default: Not set | Overrides the input layer CRS | 
| Schema (schema name) Optional | 
 | [string] Default: ‘public’ | Defines the schema for the database table | 
| Table to export to (leave blank to use layer name) Optional | 
 | [string] Default: ‘’ | Defines a name for the table that will be imported into the database. By default the table name is the name of the input vector file. | 
| Primary Key (new field) Optional | 
 | [string] Default: ‘id’ | Defines which attribute field will be the primary key of the database table | 
| Primary Key (existing field, used if the above option is left empty) Optional | 
 | [tablefield: any] Default: Not set | Defines which attribute field in the exported layer will be the primary key of the database table | 
| Geometry column name Optional | 
 | [string] Default: ‘geom’ | Defines in which attribute field of the database there will be the geometry information | 
| Vector dimensions Optional | 
 | [enumeration] Default: 0 (2D) | Defines the coordinate dimensions of the imported vector data. One of: 
 | 
| Distance tolerance for simplification Optional | 
 | [string] Default: ‘’ | Defines a distance tolerance for the simplification of the vector geometries to be imported. By default there is no simplification. | 
| Maximum distance between 2 nodes (densification) Optional | 
 | [string] Default: ‘’ | The maximum distance between two nodes. Used to create intermediate points. By default there is no densification. | 
| Select features by extent (defined in input layer CRS) Optional | 
 | [extent] Default: Not set | You can select features from a given extent that will be in the output table. Available methods are: 
 | 
| Clip the input layer using the above (rectangle) extent | 
 | [boolean] Default: False | The input layer will be clipped by the extent you defined before | 
| Select features using a SQL “WHERE” statement (Ex: column=”value”) Optional | 
 | [string] Default: ‘’ | Defines with a SQL “WHERE” statement which features should be selected from the input layer | 
| Group N features per transaction (Default: 2000) Optional | 
 | [string] Default: ‘’ | You can group the input features in transactions where N defines the size. By default N limits the transaction size to 20000 features. | 
| Overwrite existing table | 
 | [boolean] Default: True | If there is a table with the same name in the database, and if this option is set to True, the table will be overwritten. | 
| Append to existing table | 
 | [boolean] Default: False | If checked / True the vector data will be appended to an existing table. New fields found in the input layer are ignored. By default a new table will be created. | 
| Append and add new fields to existing table | 
 | [boolean] Default: False | If activated the vector data will be appended to an existing table, there won’t be a new table created. New fields found in input layer are added to the table. By default a new table will be created. | 
| Do not launder columns/table names | 
 | [boolean] Default: False | With this option checked you can prevent the default behaviour (converting column names to lowercase, removing spaces and other invalid characters). | 
| Do not create Spatial Index | 
 | [boolean] Default: False | Prevents a spatial index for the output table from being created. By default, a spatial index is added. | 
| Continue after a failure, skipping the failed feature | 
 | [boolean] Default: False | Continue after a failure, skipping the failed feature. | 
| Validate geometries based on Simple Features specification | 
 | [boolean] Default: False | Applies cleanup operations on geometries to ensure they are valid regarding the rules of the Simple Features specification. | 
| Promote to Multipart | 
 | [boolean] Default: True | Casts features geometry type to multipart in the output table | 
| Keep width and precision of input attributes | 
 | [boolean] Default: True | Avoids modifying column attributes to comply with input data | 
| Additional creation options Optional | 
 | [string] Default: ‘’ (no additional options) | Additional GDAL creation options. | 
Outputs
This algorithm has no output.
Python code
Algorithm ID: gdal:importvectorintopostgisdatabaseavailableconnections
import processing
processing.run("algorithm_id", {parameter_dictionary})
The algorithm id is displayed when you hover over the algorithm in the Processing Toolbox. The parameter dictionary provides the parameter NAMEs and values. See Using processing algorithms from the console for details on how to run processing algorithms from the Python console.
24.2.8.4. Export to PostgreSQL (new connection)
Imports vector layers inside a PostgreSQL database. A new connection to the PostGIS database must be created.
This algorithm is derived from the GDAL ogr2ogr utility.
Parameters
| Label | Name | Type | Description | 
|---|---|---|---|
| Input layer | 
 | [vector: any] | OGR-supported vector layer to export to the database | 
| Shape encoding Optional | 
 | [string] Default: ‘’ | Sets the encoding to apply to the data | 
| Output geometry type | 
 | [enumeration] Default: 0 | Defines the output geometry type. One of: 
 | 
| Assign an output CRS Optional | 
 | [crs] Default: Not set | Defines the output CRS of the database table | 
| Reproject to this CRS on output Optional | 
 | [crs] Default: Not set | Reprojects/transforms to this CRS on output | 
| Override source CRS Optional | 
 | [crs] Default: Not set | Overrides the input layer CRS | 
| Host Optional | 
 | [string] Default: ‘localhost’ | Name of the database host | 
| Port Optional | 
 | [string] Default: ‘5432’ | Port number the PostgreSQL database server listens on | 
| Username Optional | 
 | [string] Default: ‘’ | User name used to log in to the database | 
| Database name Optional | 
 | [string] Default: ‘’ | Name of the database | 
| Password Optional | 
 | [string] Default: ‘’ | Password used with Username to connect to the database | 
| Schema (schema name) Optional | 
 | [string] Default: ‘public’ | Defines the schema for the database table | 
| Table name, leave blank to use input name Optional | 
 | [string] Default: ‘’ | Defines a name for the table that will be imported into the database. By default the table name is the name of the input vector file. | 
| Primary Key (new field) Optional | 
 | [string] Default: ‘id’ | Defines which attribute field will be the primary key of the database table | 
| Primary Key (existing field, used if the above option is left empty) Optional | 
 | [tablefield: any] Default: Not set | Defines which attribute field in the exported layer will be the primary key of the database table | 
| Geometry column name Optional | 
 | [string] Default: ‘geom’ | Defines in which attribute field to store the geometry information | 
| Vector dimensions Optional | 
 | [enumeration] Default: 0 (2D) | Defines the coordinate dimensions of the imported vector data. One of: 
 | 
| Distance tolerance for simplification Optional | 
 | [string] Default: ‘’ | Defines a distance tolerance for the simplification of the vector geometries to be imported. By default there is no simplification. | 
| Maximum distance between 2 nodes (densification) Optional | 
 | [string] Default: ‘’ | The maximum distance between two nodes. Used to create intermediate points. By default there is no densification. | 
| Select features by extent (defined in input layer CRS) Optional | 
 | [extent] Default: Not set | You can select features from a given extent that will be in the output table. Available methods are: 
 | 
| Clip the input layer using the above (rectangle) extent | 
 | [boolean] Default: False | The input layer will be clipped by the extent you defined before | 
| Fields to include (leave empty to use all fields) Optional | 
 | [string] [list] Default: [] | Defines fields to keep from the imported vector file. If none is selected, all the fields are imported. | 
| Select features using a SQL “WHERE” statement (Ex: column=”value”) Optional | 
 | [string] Default: ‘’ | Defines with a SQL “WHERE” statement which features should be selected for the output table | 
| Group N features per transaction (Default: 2000) Optional | 
 | [string] Default: ‘’ | You can group the input features in transactions where N defines the size. By default N limits the transaction size to 20000 features. | 
| Overwrite existing table | 
 | [boolean] Default: True | If there is a table with the same name in the database, and if this option is set to True, the table will be overwritten. | 
| Append to existing table | 
 | [boolean] Default: False | If checked / True the vector data will be appended to an existing table. New fields found in the input layer are ignored. By default a new table will be created. | 
| Append and add new fields to existing table | 
 | [boolean] Default: False | If activated the vector data will be appended to an existing table, there won’t be created a new table. New fields found in input layer are added to the table. By default a new table will be created. | 
| Do not launder columns/table names | 
 | [boolean] Default: False | With this option checked you can prevent the default behaviour (converting column names to lowercase, removing spaces and other invalid characters). | 
| Do not create Spatial Index | 
 | [boolean] Default: False | Prevents a spatial index for the output table from being created. By default, a spatial index is added. | 
| Continue after a failure, skipping the failed feature | 
 | [boolean] Default: False | Continue after a failure, skipping the failed feature. | 
| Validate geometries based on Simple Features specification | 
 | [boolean] Default: False | Applies cleanup operations on geometries to ensure they are valid regarding the rules of the Simple Features specification. | 
| Promote to Multipart | 
 | [boolean] Default: True | Casts features geometry type to multipart in the output table | 
| Keep width and precision of input attributes | 
 | [boolean] Default: True | Avoids modifying column attributes to comply with input data | 
| Additional creation options Optional | 
 | [string] Default: ‘’ (no additional options) | Additional GDAL creation options. | 
Outputs
This algorithm has no output.
Python code
Algorithm ID: gdal:importvectorintopostgisdatabasenewconnection
import processing
processing.run("algorithm_id", {parameter_dictionary})
The algorithm id is displayed when you hover over the algorithm in the Processing Toolbox. The parameter dictionary provides the parameter NAMEs and values. See Using processing algorithms from the console for details on how to run processing algorithms from the Python console.
24.2.8.5. Vector Information
Creates an information file that lists information about an OGR-supported data source. The output will be shown in a ‘Result’ window and can be written into a HTML-file. The information includes the geometry type, feature count, the spatial extent, the projection information, the list of attributes and related type, list of relations and field domains, and many more.
This algorithm is derived from the GDAL ogrinfo utility.
Parameters
Basic parameters
| Label | Name | Type | Description | 
|---|---|---|---|
| Input layer | 
 | [vector: geometry] | Input vector layer | 
| Enable listing of all layers in the dataset | 
 | [boolean] Default: False | If checked, QGIS will output the information of all the layers in the input dataset instead of information of the first layer only. Convenient when a multi layer format (GeoPackage, GML, KML, SpatiaLite, SQLite, …) is used as input. | 
| Summary output only | 
 | [boolean] Default: True | Suppress listing of individual features and show only summary information like projection, schema, feature count and extents. | 
| Suppress metadata info | 
 | [boolean] Default: False | Suppress metadata printing. Some datasets may contain a lot of metadata strings. | 
| Layer information | 
 | [html] Default:  | Specify the output HTML file that includes the file information. One of: 
 If no HTML-file is defined the output will be written to a temporary file | 
Advanced parameters
| Label | Name | Type | Description | 
|---|---|---|---|
| Additional command line parameters Optional | 
 | [string] Default: ‘’ (no additional options) | Add extra GDAL command line options | 
Outputs
| Label | Name | Type | Description | 
|---|---|---|---|
| Layer information | 
 | [html] | The output HTML-file that includes the file information. | 
Python code
Algorithm ID: gdal:ogrinfo
import processing
processing.run("algorithm_id", {parameter_dictionary})
The algorithm id is displayed when you hover over the algorithm in the Processing Toolbox. The parameter dictionary provides the parameter NAMEs and values. See Using processing algorithms from the console for details on how to run processing algorithms from the Python console.
24.2.8.6. Vector Information (JSON)
Creates an information file that lists information about an
OGR-supported data source.
The output will be shown in a ‘Result’ window and can be written
into a .JSON file.
The information includes the geometry type, feature count, the spatial
extent, the projection information, the list of attributes and related type,
list of relations and field domains, and many more.
This algorithm is derived from the GDAL ogrinfo utility.
Requires version of GDAL >= 3.7
Parameters
Basic parameters
| Label | Name | Type | Description | 
|---|---|---|---|
| Input layer | 
 | [vector: geometry] | Input vector layer | 
| Enable listing of all layers in the dataset | 
 | [boolean] Default: False | If checked, QGIS will output the information of all the layers in the input dataset instead of information of the first layer only. Convenient when a multi layer format (GeoPackage, GML, KML, SpatiaLite, SQLite, …) is used as input. | 
| Enable listing of features | 
 | [boolean] Default: False | |
| Suppress metadata info | 
 | [boolean] Default: False | Suppress metadata printing. Some datasets may contain a lot of metadata strings. | 
| Layer information | 
 | [file] Default:  | Specify the output JSON file that includes the file information. One of: 
 If no JSON file is defined the output will be written to a temporary file | 
Advanced parameters
| Label | Name | Type | Description | 
|---|---|---|---|
| Additional command line parameters Optional | 
 | [string] Default: ‘’ (no additional options) | Add extra GDAL command line options | 
Outputs
| Label | Name | Type | Description | 
|---|---|---|---|
| Layer information | 
 | [file] | The output .JSON file that includes the file information. | 
Python code
Algorithm ID: gdal:ogrinfojson
import processing
processing.run("algorithm_id", {parameter_dictionary})
The algorithm id is displayed when you hover over the algorithm in the Processing Toolbox. The parameter dictionary provides the parameter NAMEs and values. See Using processing algorithms from the console for details on how to run processing algorithms from the Python console.