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 :

nom d'une liste à partir de valeurs de variables


Sujet :

Python

  1. #1
    Nouveau membre du Club
    Inscrit en
    Mars 2007
    Messages
    39
    Détails du profil
    Informations forums :
    Inscription : Mars 2007
    Messages : 39
    Points : 35
    Points
    35
    Par défaut nom d'une liste à partir de valeurs de variables
    Bonjour,

    Mon problème est le suivant:

    j'ai des variables var1 et var2 que j'obtient par un calcul.
    Une fois ça fait, j'aimerais créer une liste qui dans son nom contient les valeurs de var1 et var2. Du style : liste_valeur(var1)_valeur(var2) =[]

    Merci bien.

  2. #2
    Membre expérimenté Avatar de pacificator
    Profil pro
    Inscrit en
    Août 2006
    Messages
    1 074
    Détails du profil
    Informations personnelles :
    Âge : 45
    Localisation : France

    Informations forums :
    Inscription : Août 2006
    Messages : 1 074
    Points : 1 728
    Points
    1 728

  3. #3
    Membre éclairé
    Avatar de GnuVince
    Profil pro
    Développeur informatique
    Inscrit en
    Avril 2004
    Messages
    679
    Détails du profil
    Informations personnelles :
    Localisation : Canada

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Avril 2004
    Messages : 679
    Points : 803
    Points
    803
    Par défaut
    C'est possible, mais c'est une TRÈS mauvaise chose à faire. Je te suggérerais d'utiliser un dict à la place:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
     
    var1 = calcul1()
    var2 = calcul2()
    d = {}
    d['%s%s' % (var1, var2)] = []
    Si tu veux absolument créer une nouvelle variable, voici la façon de faire:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
     
    locals()['variable'] = 'valeur'
    print variable
    Je répète que ce genre de code est extrêmement fragile, et tu devrais donc utiliser la première technique.

  4. #4
    Nouveau membre du Club
    Inscrit en
    Mars 2007
    Messages
    39
    Détails du profil
    Informations forums :
    Inscription : Mars 2007
    Messages : 39
    Points : 35
    Points
    35
    Par défaut
    merci pr ces réponses.

    Je ne comprends pas bien pourquoi le faire avec une liste est dangereux...
    J'ai essayé avec un dico mais ça ne marche pas tjrs (probleme sur mon ordi?), donc je ne suis pas arrivé à faire ce que je voulais.
    Je voulais le faire avec une liste car cela me paraissait plus simple ainsi.

    Je réexplique mon problème plus clairement:
    je lis un fichier en entrée ligne par ligne. Chaque ligne représente un point avec ses coordonnées x, y. Ce que je veux c'est "ranger" ces points au fur et à mesure dans des cases virtuelles en fonction de leurs coordonnées.
    Pour l'instant j'arrive à savoir dans quelle case case(i,j) chaque point appartient.
    Maintenant j'aimerais pour chaque point que je lis:
    -créer une liste (ou autre) dont le nom contienne i et j (par ex: liste_i_j) ,si elle n'existe pas déjà
    -ajouter ce point à cette liste.

    ceci mon pose un autre probleme, comment savoir si une liste existe déjà? j'ai essayé en regardant avec dir() en la parcourant et si il ne trouve pas la liste liste_i_j dans dir() alors je lui demande de la créer. ça marche mais parcontre quand la liste liste_i_j existe il ne la reconnait pas.

    avez-vous des suggestions?

  5. #5
    Nouveau membre du Club
    Profil pro
    Étudiant
    Inscrit en
    Mai 2007
    Messages
    47
    Détails du profil
    Informations personnelles :
    Âge : 36
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Mai 2007
    Messages : 47
    Points : 36
    Points
    36
    Par défaut
    si tes coordonnées sont des entiers rangés dans var1 et var2 tu peux faire

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    l = [int(Var1),int(Var2)]
    pour savoir si la liste existe ou non tu pourrais définir une exception de sorte que lorsque l'appel de ta liste génere une erreur quand celle ci n'existe pas et puis tu filtre pour rattraper ton exception

    Je connais pas la syntaxe en python mais tu devrais trouver cela facilement t sur le net.

    Avec des mots:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    définir l'exception error "zut, pas de liste"
    puis 
     
    try 
     
    corps de ta fonction
     
    with
     
    error -> # la liste n'existe pas, et bien créons la
                l = [int(Var1),int(Var2)]
                on relance l'algo ...
    Rémy.

  6. #6
    Nouveau membre du Club
    Inscrit en
    Mars 2007
    Messages
    39
    Détails du profil
    Informations forums :
    Inscription : Mars 2007
    Messages : 39
    Points : 35
    Points
    35
    Par défaut
    merci bien.

    problème résolu.

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. Extraction d'une liste à partir de la valeur d'une cellule
    Par lps02 dans le forum Macros et VBA Excel
    Réponses: 1
    Dernier message: 04/07/2012, 20h07
  2. [SP-2010] Filtrer une liste à partir d'un http://url?parametre=valeur
    Par Goupo dans le forum SharePoint
    Réponses: 4
    Dernier message: 12/07/2010, 12h08
  3. Créer une liste à partir des noms des feuilles
    Par BOU59000 dans le forum Macros et VBA Excel
    Réponses: 10
    Dernier message: 19/08/2008, 18h38
  4. Réponses: 8
    Dernier message: 02/04/2008, 15h31
  5. Réponses: 8
    Dernier message: 27/06/2006, 11h47

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