gdal vector export-schema
Added in version 3.13.
Export the OGR_SCHEMA from a vector dataset.
OGR_SCHEMA is a JSON object describing the structure of a vector dataset according to the schema definition at ogr_fields_override.schema.json
Synopsis
Usage: gdal vector export-schema [OPTIONS] <INPUT>...
Export the OGR_SCHEMA from a vector dataset.
Positional arguments:
-i, --dataset, --input <INPUT> Input vector datasets [may be repeated] [required]
Common Options:
-h, --help Display help message and exit
--json-usage Display usage as JSON document and exit
--config <KEY>=<VALUE> Configuration option [may be repeated]
Options:
-l, --layer, --input-layer <INPUT-LAYER> Input layer name [may be repeated]
Advanced Options:
--oo, --open-option <KEY>=<VALUE> Open options [may be repeated]
--if, --input-format <INPUT-FORMAT> Input formats [may be repeated]
Description
gdal vector export-schema exports the OGR_SCHEMA from a GDAL-supported
vector dataset, and returns it on the standard output stream when used from the
command line, or in the output parameter when used from the API.
OGR_SCHEMA is a JSON object describing the structure of a vector dataset
according to the schema definition at ogr_fields_override.schema.json
gdal vector export-schema can be used as the last step of a pipeline.
The following options are available:
Program-Specific Options
- -l, --layer, --input-layer <INPUT-LAYER>
Name of one or more layers to inspect. If no layer names are passed, then all layers will be selected.
Standard Options
Details
- --oo, --open-option <NAME>=<VALUE>
Dataset open option (format specific).
May be repeated.
- --if, --input-format <format>
Format/driver name to be attempted to open the input file(s). It is generally not necessary to specify it, but it can be used to skip automatic driver detection, when it fails to select the appropriate driver. This option can be repeated several times to specify several candidate drivers. Note that it does not force those drivers to open the dataset. In particular, some drivers have requirements on file extensions.
May be repeated.
Return status code
The program returns status code 0 in case of success, and non-zero in case of error (non-blocking errors emitted as warnings are considered as a successful execution).
Examples
Example 1: Extracting the OGR_SCHEMA from the file poly.gpkg
gdal vector export-schema poly.gpkg
Example 2: Save the OGR_SCHEMA to a file
When using Windows PowerShell 5.1, redirecting output with > or Out-File -Encoding utf8
produces UTF-8 with a BOM (Byte Order Mark). When using the schema with gdal vector create
it may fail with ERROR 1: JSON parsing error: unexpected character (at offset 0).
In PowerShell 5.1, use -Encoding ascii for JSON output that contains no non-ASCII characters.
gdal vector export-schema natural_earth_vector.gpkg --layer "ne_50m_admin_0_countries" > countries.json
# PowerShell 5.1
gdal vector export-schema natural_earth_vector.gpkg --layer "ne_50m_admin_0_countries" | Out-File countries.json -Encoding ascii
# PowerShell 7+
gdal vector export-schema natural_earth_vector.gpkg --layer "ne_50m_admin_0_countries" | Out-File countries.json -Encoding utf8
Example 3: Validate an OGR_SCHEMA file using Python
Validate against the latest version of the schema definition at ogr_fields_override.schema.json using the Python package check-jsonschema available on PyPI.
$ pip install check-jsonschema
$ check-jsonschema --schemafile https://raw.githubusercontent.com/OSGeo/gdal/master/ogr/data/ogr_fields_override.schema.json countries.json --verbose
Example 4: Create an OGR_SCHEMA at the end of a pipeline
This example renames the field pop_est to estimated_population and changes its
type from Real to Integer, before exporting the resulting OGR_SCHEMA.
gdal vector pipeline \
! read natural_earth_vector.gpkg --layer ne_50m_admin_0_countries \
! sql --sql "SELECT geom,name,abbrev,pop_est AS estimated_population FROM ne_50m_admin_0_countries" --output-layer "countries" \
! set-field-type --field-name "estimated_population" --field-type Integer \
! export-schema
gdal vector pipeline `
! read natural_earth_vector.gpkg --layer ne_50m_admin_0_countries `
! sql --sql "SELECT geom,name,abbrev,pop_est AS estimated_population FROM ne_50m_admin_0_countries" --output-layer "countries" `
! set-field-type --field-name "estimated_population" --field-type Integer `
! export-schema