Sous Windows, pour utiliser efficacement psql, shp2pgsql, pgsql2shp, ogr2ogr... Et après avoir installé QGIS (car il embarque GDAL/OGR et PROJ), et/ou MySQL, et/ou Postgres, il faudra sans doute préciser quelques variables d'environnement.

Ceci pour que Windows, et vous, puissiez accéder à ces outils en ligne de commande. Lignes de commande que vous pourrez ensuite inclure dans votre langage de programmation préféré (Python, PHP, Java...), permettant donc des combos très puissants.

À savoir 🙂

  • Préférez l'installation classique de QGIS (à l'architecture plus claire il me semble), et non pas l'installateur réseau OSGeo4W (à l'architecture plus complexe). De plus les versions QGIS 3.28.X me semblent avoir une architecture plus simple à comprendre pour identifier les différentes librairies (par rapport aux versions 3.34.X par exemple).
  • Plusieurs versions de Python, Pip et QGIS peuvent co-exister sur votre machine (et co-existeront probablement, lol).
  • Selon les versions de QGIS, les chemins peuvent avoir changé, c'est à vous de les identifier avant de les utiliser dans les variables d'environnement. Les exemples ci-dessous s'inspirent de QGIS 3.28.13 sur Windows 11.
  • Très généralement, Pip est déjà embarqué dans le Python de QGIS (et donc déjà disponible depuis le shell d'OSGeo, mais pas nativement depuis celui de Windows).
  • Pour une modification soit prise en compte, il faudra fermer toutes les fenêtes qui vous ont permis d'accéder aux variables d'environnement. Il faudra aussi relancer le shell Windows (l'invite de commandes), afin de prendre en compte certaines modifications des variables d'environnement.
  • Si vous avez déjà installé Postgres, il est possible que certaines variables liées à GDAL/OGR et PROJ aient déjà été créées, mais nous allons ici préférer les versions de QGIS, plus claires, modifiez donc les éventuelles variables existantes.
  • On ne touchera ici qu'aux variables système.

GDAL/OGR

Créez une variable GDAL_DATA avec une valeur ressemblant à ces exemples :

C:\Program Files\QGIS [version]\apps\gdal\share\gdal
C:\QGIS [version]\share\gdal

Créez une variable GDAL_DRIVER_PATH avec une valeur ressemblant à ces exemples :

C:\Program Files\QGIS [version]\apps\gdal\lib\gdalplugins
C:\QGIS [version]\bin\gdalplugins

Créez une variable PROJ_LIB avec une valeur ressemblant à ces exemples :

C:\Program Files\QGIS [version]\share\proj
C:\QGIS [version]\share\proj

Ajoutez dans la variable système Path quelque chose comme :

C:\Program Files\QGIS [version]\bin
C:\QGIS [version]\bin

À ce stade, vous devriez pouvoir lancer cette commande dans le shell Windows (l'invite de commandes, après l'avoir relancé s'il était déjà ouvert) :

ogr2ogr.exe --version

Bien, si cela affiche la version de GDAL/OGR, vous allez pouvoir l'utiliser en ligne de commande !

Installateur réseau OSGeo4W

Seulement si QGIS a été installé via l'installateur réseau OSGeo4W (mais j'ai constaté des bugs, ou du moins des difficultés, préférez l'installation classique de QGIS en stand-alone, et donc les variables décrites au-dessus) :

GDAL_DATA = C:\OSGeo4W\share\gdal
GDAL_DRIVER_PATH = C:\OSGeo4W\bin\gdalplugins

MySQL

Éventuellement pour MySQL, ajoutez dans la variable système Path quelque chose comme :

C:\Program Files\MySQL\MySQL Server [version]\bin

À ce stade, vous devriez pouvoir lancer une commande similaire à celle-ci dans le shell Windows (l'invite de commandes, après l'avoir relancé s'il était déjà ouvert, et après avoir mis vos accès) :

ogrinfo MYSQL:"my_db,user=root,password=root,port=3306"

Bien, si cela liste les tables présentes dans votre base de données, vous allez pouvoir l'utiliser en ligne de commande et interagir avec GDA/OGR !

Et la variante pour pointer sur une base de données distante (host) :

ogrinfo MYSQL:"my_db,user=root,password=root,port=3306,host:11.111.11.11"

Postgres

Éventuellement pour Postgres et PSQL, ajoutez dans la variable système Path :

C:\Program Files\PostgreSQL\[version]\bin

Ensuite il est courant d'accorder la confiance à son poste local, ce qui simplifiera les lignes de commandes. Pour cela trouvez le fichier pg_hba.conf, qui se trouve dans le répertoire data de votre version de Postgres, ce qui dépendra donc de votre version mais aussi du choix que vous avez fait à l'installation, exemples :

C:\Program Files\PostgreSQL\[version]\data\pg_hba.conf
[disque dur]:\[répertoire customisé]\pg_hba.conf

Ouvrez-le et cherchez la chaîne IPv6 local connections, ou scram-sha-256 (vers la fin du fichier sans doute), et modifiez la METHOD comme suit (scram-sha-256 devient trust) :

# IPv6 local connections:
host all all ::1/128 trust

À ce stade, vous devriez pouvoir lancer ces commande dans le shell Windows (après l'avoir relancé s'il était déjà ouvert) :

pgsql2shp

Bien, si cela liste la version de l'outil et quelques exemples de lignes de commande, vous allez pouvoir exporter des shapes depuis Posgtres, avec moult options !

shp2pgsql

Bien, si cela liste la version de l'outil et quelques exemples de lignes de commande, vous allez pouvoir importer des shapes dans Posgtres, avec moult options !

psql -h localhost -p 5432 -d ma_bdd -U mon_user -c "SELECT * FROM ma_table;"

Bien, si cela affiche votre table, vous allez pouvoir manipuler Posgtres en lignes de commande !

Python

Éventuellement pour Python.

Dans le shell Windows (invite de commandes), vous pouvez d'abord lancer ceci pour vérifier quelles sont les versions de Python existantes sur votre machine :

where python

Puis éventuellement, pour Python, toujours après avoir vérifié que ces chemins existent, et toujours dans la variable Path de vos variables système, ajoutez quelque chose comme :

C:\Users\[user]\AppData\Local\Programs\Python\Python39

Pour lancer Python depuis le shell Windows (invite de commandes) :

python
py
python3

Pip

À l'installation de Pip via le shell Windows (un tutoriel ici), il vous proposera sans doute de se mettre à jour et de l'enregistrer dans la variable Path, faîtes donc, en plus il vous fournira le bon chemin.

Éventuellement, pour Pip et d'autres scripts importants, toujours après avoir vérifié que ces chemins existent, toujours dans la variable Path de vos variables système, ajoutez quelque chose comme :

C:\Users\[user]\AppData\Roaming\Python\Python39\Scripts

Et/ou :

C:\Users\[user]\AppData\Local\Programs\Python\Python39\Scripts

À ce stade, et après avoir redémarré le shell Windows et/ou celui de OSGeo, vous devriez pouvoir y installer des librairies de ces façons par exemple :

python install wikipedia
python -m pip install wikipedia
python -m pip install wikipedia --user

Divers

Dans cet autre article se trouve un chapitre sur l'installation de modules Python tiers dans QGIS (depuis le Pip du shell d'OSGeo).

Dans cet autre article se trouve une série de pratiques pour traiter des données avec Python, Pandas, Geopandas... y compris dans des BDD SQL, y compris avec une composante géographique.