QGIS - est-il possible de convertir des caractères accentués en caractères réguliers dans la table attributaire? [fermé]


9

J'ai un ensemble de données OSM contenant des noms avec des caractères nationaux (c'est une exportation CSV, mais je l'ai dans SHP):

osm_id,code,fclass,population,name,longitude,latitude
276645544,1003,village,221,Krč,14.248410,49.194988
444571400,1003,village,88,Radonice,14.548085,49.143251
488567474,1003,village,115,Doubravka,14.363835,49.282158
488567478,1003,village,114,Koloměřice,14.399437,49.280328
488567484,1003,village,111,Údraž,14.309249,49.281551
491452727,1004,hamlet,33,Poněšice,14.481200,49.105121
601855465,1003,village,147,Hvožďany,14.433230,49.286094
631878480,1003,village,211,Myšenec,14.208999,49.223213

et souhaite les convertir sous cette forme:

osm_id,code,fclass,population,name,longitude,latitude
276645544,1003,village,221,Krc,14.248410,49.194988
444571400,1003,village,88,Radonice,14.548085,49.143251
488567474,1003,village,115,Doubravka,14.363835,49.282158
488567478,1003,village,114,Kolomerice,14.399437,49.280328
488567484,1003,village,111,Udraz,14.309249,49.281551
491452727,1004,hamlet,33,Ponesice,14.481200,49.105121
601855465,1003,village,147,Hvozdany,14.433230,49.286094
631878480,1003,village,211,Mysenec,14.208999,49.223213

où les accents sont supprimés donc au lieu de "č, š, ř, á" etc. vous avez "c, s, r, a". Je n'ai pas besoin de modifier la colonne actuelle - pourrait créer une nouvelle colonne avec des noms convertis.

Je vais actuellement utiliser un outil en ligne comme celui-ci pour le fichier CSV, mais ce serait bien si je pouvais résoudre ce problème directement dans QGIS.


1
pourquoi hors sujet? Je demande principalement une solution directe dans QGIS sans avoir besoin d'exporter mes données vers CSV et d'importer à nouveau.
Juhele

Réponses:


9

Oui, c'est possible avec la bibliothèque unidecode en python ... ( documentation ). Cela essaie de trouver l'équivalent ASCII le plus proche de chaque caractère unicode.

from unidecode import unidecode

s="""
osm_id,code,fclass,population,name,longitude,latitude
276645544,1003,village,221,Krč,14.248410,49.194988
444571400,1003,village,88,Radonice,14.548085,49.143251
488567474,1003,village,115,Doubravka,14.363835,49.282158
488567478,1003,village,114,Koloměřice,14.399437,49.280328
488567484,1003,village,111,Údraž,14.309249,49.281551
491452727,1004,hamlet,33,Poněšice,14.481200,49.105121
601855465,1003,village,147,Hvožďany,14.433230,49.286094
631878480,1003,village,211,Myšenec,14.208999,49.223213
"""

print(unidecode(s))

production:-

osm_id,code,fclass,population,name,longitude,latitude
276645544,1003,village,221,Krc,14.248410,49.194988
444571400,1003,village,88,Radonice,14.548085,49.143251
488567474,1003,village,115,Doubravka,14.363835,49.282158
488567478,1003,village,114,Kolomerice,14.399437,49.280328
488567484,1003,village,111,Udraz,14.309249,49.281551
491452727,1004,hamlet,33,Ponesice,14.481200,49.105121
601855465,1003,village,147,Hvozdany,14.433230,49.286094
631878480,1003,village,211,Mysenec,14.208999,49.223213

Ce code convertira un fichier CSV en un autre: -

from unidecode import unidecode
with open("/path/to/original.csv", "r") as input_file:
    with open("/path/to/converted.csv","w") as output_file:
        output_file.write(unidecode(input_file.read()))

1
Hmm, on dirait que je ne peux pas éviter d'exporter en CSV et de réimporter. Je proposerai probablement une fonctionnalité telle que l'amélioration de QGIS.
Juhele
En utilisant notre site, vous reconnaissez avoir lu et compris notre politique liée aux cookies et notre politique de confidentialité.
Licensed under cc by-sa 3.0 with attribution required.