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.

Juhele
la source
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()))
Steven Kay
la source
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