IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

Python Discussion :

Si ma string est alphabeticalement avant une autre ou entre deux strings


Sujet :

Python

  1. #1
    Membre à l'essai
    Inscrit en
    Avril 2010
    Messages
    36
    Détails du profil
    Informations forums :
    Inscription : Avril 2010
    Messages : 36
    Points : 24
    Points
    24
    Par défaut Si ma string est alphabeticalement avant une autre ou entre deux strings
    Bonjour à vous,

    Je suis pas très bon en dev mais j'essaye de me soigner

    Je suis face a un problème et je ne sais pas réellement comment le résoudre.

    J'ai un fichier JSON qui gère des traductions de langues que je souhaite modifier.
    J'ai 8 langues à ajouter a mon fichier et je me dis que manuellement c'est injouable.

    Pour repérer les traductions, le JSON utilise les codes iso des langue (fr_FR, es_ES, etc).

    Je vais avoir plusieurs langue à ajouter (bg_BG, fi_FI, etc ...)

    Je voudrais savoir s'il y a une méthode simple pour comparer "bg_BG" à "fr_FR" pour savoir si ma string est avant celle a laquelle je la compare ou si elle est comprise entre 2 strings.

    Je me dis que comme ça je peux faire:
    Si bg_BG est avant fr_FR alors insérer la traduction avant fr_FR ....

    Existe-il un opérateur qui fait directement l'opération ou il faut faire autrement (découper les strings et comparer char par char?)?

    Merci par avance

    Thomas

  2. #2
    Expert éminent sénior
    Homme Profil pro
    Architecte technique retraité
    Inscrit en
    Juin 2008
    Messages
    21 287
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Manche (Basse Normandie)

    Informations professionnelles :
    Activité : Architecte technique retraité
    Secteur : Industrie

    Informations forums :
    Inscription : Juin 2008
    Messages : 21 287
    Points : 36 776
    Points
    36 776
    Par défaut
    Salut,

    Citation Envoyé par Canyata Voir le message
    Existe-il un opérateur qui fait directement l'opération ou il faut faire autrement (découper les strings et comparer char par char?)?
    Les opérateurs de comparaison normaux - <, >, <=,... - fonctionnent suivant l'ordre lexicographique modulo que minuscules < majuscules. Et cela s'applique à n'importe quelle séquence (chaines de caractères, listes, tuples).

    - W
    Architectures post-modernes.
    Python sur DVP c'est aussi des FAQs, des cours et tutoriels

  3. #3
    Membre à l'essai
    Inscrit en
    Avril 2010
    Messages
    36
    Détails du profil
    Informations forums :
    Inscription : Avril 2010
    Messages : 36
    Points : 24
    Points
    24
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
     
    if "bg_BG" < "cs_CZ" :
        print "BG is before CZ"
     
    if "cs_CZ" > "bg_BG" :
        print "CZ is before BG"
    Resultat:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    BG is before CZ
    CZ is before BG
    Ca me print les 2. L'opérateur ne marche pas?

    L'opérateur ne marche pas?

  4. #4
    Membre averti Avatar de zancrows
    Homme Profil pro
    Étudiant
    Inscrit en
    Décembre 2016
    Messages
    155
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Côtes d'Armor (Bretagne)

    Informations professionnelles :
    Activité : Étudiant
    Secteur : Industrie

    Informations forums :
    Inscription : Décembre 2016
    Messages : 155
    Points : 346
    Points
    346
    Par défaut
    Citation Envoyé par Canyata Voir le message
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
     
    if "bg_BG" < "cs_CZ" :
        print "BG is before CZ"
     
    if "cs_CZ" > "bg_BG" :
        print "CZ is before BG"
    Resultat:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    BG is before CZ
    CZ is before BG
    Ca me print les 2. L'opérateur ne marche pas?

    L'opérateur ne marche pas?
    Bonjour, si tu fais la même comparaison normal que ca t’affiche les deux

  5. #5
    Expert éminent

    Homme Profil pro
    Inscrit en
    Octobre 2008
    Messages
    4 300
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Belgique

    Informations forums :
    Inscription : Octobre 2008
    Messages : 4 300
    Points : 6 780
    Points
    6 780
    Par défaut
    Salut,

    Ce que je ne comprend pas trop c'est que le fichier json sera transformé en dictionnaire, or les dictionnaires ne sont pas ordonnés, donc pourquoi te fier à l'ordre alphabétique ?

    Par contre lors de l'enregistrement vers le json tu pourras forcer l'ordre avec l'argument sort_keys=True

  6. #6
    Membre à l'essai
    Inscrit en
    Avril 2010
    Messages
    36
    Détails du profil
    Informations forums :
    Inscription : Avril 2010
    Messages : 36
    Points : 24
    Points
    24
    Par défaut
    Citation Envoyé par zancrows Voir le message
    Bonjour, si tu fais la même comparaison normal que ca t’affiche les deux
    Put*** mais quel c**

    Merci mdr

  7. #7
    Membre à l'essai
    Inscrit en
    Avril 2010
    Messages
    36
    Détails du profil
    Informations forums :
    Inscription : Avril 2010
    Messages : 36
    Points : 24
    Points
    24
    Par défaut
    Citation Envoyé par VinsS Voir le message
    Salut,

    Ce que je ne comprend pas trop c'est que le fichier json sera transformé en dictionnaire, or les dictionnaires ne sont pas ordonnés, donc pourquoi te fier à l'ordre alphabétique ?

    Par contre lors de l'enregistrement vers le json tu pourras forcer l'ordre avec l'argument sort_keys=True
    L'import se fait via un excel que je mets en forme directement via le python.

    Je lis mon excel, je lis mon json des que je suis au bon endroit je mets en forme et j'écris dans le json.

  8. #8
    Expert éminent

    Homme Profil pro
    Inscrit en
    Octobre 2008
    Messages
    4 300
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Belgique

    Informations forums :
    Inscription : Octobre 2008
    Messages : 4 300
    Points : 6 780
    Points
    6 780
    Par défaut
    Heu, il n'est pas possible d'écrire à un endroit spécifique dans un dictionnaire python.

    Donc, nous ne parlons sans doute pas de la même chose.

  9. #9
    Membre émérite

    Homme Profil pro
    Ingénieur calcul scientifique
    Inscrit en
    Mars 2013
    Messages
    1 229
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Alpes Maritimes (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Ingénieur calcul scientifique

    Informations forums :
    Inscription : Mars 2013
    Messages : 1 229
    Points : 2 328
    Points
    2 328
    Par défaut
    Ca ne serait pas plus simple de :
    1) importer tout ce qu'il faut en Python (le json et votre tableur excel)
    2) concatener les 2 dans une structure python
    3) écrire le json de l'ensemble

    Plutot que de vouloir insérer des lignes dans un fichier ...

    Si vous n'avez pas à manipuler un ficher de plusieurs Go, ca devrait passer sans problème.

Discussions similaires

  1. Réponses: 6
    Dernier message: 09/01/2008, 11h56
  2. "la webcam est utilisée par une autre application!" ah bon???
    Par cortex024 dans le forum Périphériques
    Réponses: 2
    Dernier message: 04/05/2006, 12h13
  3. Réponses: 1
    Dernier message: 22/12/2005, 17h28
  4. [C#]Fonction vérifiant qu'1 string est contenue ds 1 autre
    Par closo dans le forum Windows Forms
    Réponses: 3
    Dernier message: 30/06/2005, 13h41
  5. Réponses: 5
    Dernier message: 26/09/2004, 19h38

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo