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 :

liste et slicing


Sujet :

Python

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Futur Membre du Club
    Profil pro
    Inscrit en
    Mars 2006
    Messages
    3
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mars 2006
    Messages : 3
    Par défaut liste et slicing
    bonjour @ tous

    petite question :

    soit une liste a de n,n+1 ou plus d'éléments.
    soit a1 une sous liste de a (les x premiers éléments)
    soit a2 une sous liste de a (les y derniers éléments)

    Le but du jeu est d'obtenir une nouvelle liste b telle que :
    b = a1 + a3 + a2
    avec a3 = une liste ne contenant qu'un string à savoir tous les éléments de a privés de a1 et a2

    Pour le moment, j'ai trouvé 2 solutions, mais je voulais vos avis et conseils

    a = ['1','2','3','4','5','6','7','8','9']
    pour que b = ['1','2','3 4 5 6','7','8','9']

    solution 1 :
    b = a[:2]+[' '.join(a[2:-3])]+a[-3:]

    solution 2 :
    a[2:-3] = [' '.join(a[2:-3])]
    b = a

    b = ['1','2','3 4 5 6','7','8','9'] dans les 2 cas
    mais je me demandais s'il n'y avait pas quelque chose d'encore plus propre ou plus rapide, ou une fonction dédiée ^^

    Merci à vous

  2. #2
    Membre Expert
    Homme Profil pro
    Inscrit en
    Mars 2007
    Messages
    941
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Belgique

    Informations forums :
    Inscription : Mars 2007
    Messages : 941
    Par défaut
    Cela me parait assez propre comme ça; et le besoin est trop ésotérique pour exister comme fonction de la libraire standard.

  3. #3
    Membre Expert
    Profil pro
    Inscrit en
    Janvier 2007
    Messages
    1 418
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2007
    Messages : 1 418
    Par défaut
    Comme l'a dit dividee, je ne vois pas ce qu'on peut espérer de mieux que join() pour effectuer la tâche assignée.

    - Mais dans ta solution 2, on peut se demander pourquoi tu fais a[2:-3] = [' '.join(a[2:-3])]
    avant b=a car tu modifies ainsi la liste a.
    Tandis que
    b = a
    b[2:-3] = [' '.join(b[2:-3])]

    devrait permettre de garder a intacte....
    .....enfin presque.... parce qu'il y a un autre problème:

    - les deux manières que tu présentes ne sont pas strictement équivalentes.

    Écrire b = a crée en effet un alias (nommé b) de a c'est à dire une sorte de pointeur vers a qui va diriger vers la liste a quand on invoquera b.
    Dans ce cas, b ne sera absolument pas une liste supplémentaire à a; la liste a pourra avoir 13 millions d'éléments, la création de b ne créera pas une liste supplémentaire de 13 millions d'éléments.
    Et toute action sur b retentira sur a.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    a = ['1','2','3','4','5','6','7','8','9']
    b = a[:2]+[' '.join(a[2:-3])]+a[-3:]
    print "Solution 1\napres creationde b :"
    print '  a =',a
    print '  b =',b
    b[1] = 'jjjjjj'
    print "apres  b[1] = 'jjjjjj' :"
    print '  a =',a
    print '  b =',b
     
    print '--------------'
     
    a = ['1','2','3','4','5','6','7','8','9']
    a[2:-3] = [' '.join(a[2:-3])]
    b = a
    print "Solution 2\napres modification de a et ecriture b=a :"
    print '  a =',a
    print '  b =',b
    b[1] = 'kkkkkk'
    print "apres  b[1] = 'kkkkkk' :"
    print '  a =',a
    print '  b =',b
     
    print '--------------'
     
    a = ['1','2','3','4','5','6','7','8','9']
    b = a
    b[2:-3] = [' '.join(b[2:-3])]
    print "Solution 2 inversee\napres ecriture b=a et modification de b :"
    print '  a =',a
    print '  b =',b
    b[1] =  'mmmmm' 
    print "apres  b[1] = 'mmmmm' :"
    print '  a =',a
    print '  b =',b
     
    print '--------------'
    Résultat
    Solution 1
    apres creationde b :
    a = ['1', '2', '3', '4', '5', '6', '7', '8', '9']
    b = ['1', '2', '3 4 5 6', '7', '8', '9']
    apres b[1] = 'jjjjjj' :
    a = ['1', '2', '3', '4', '5', '6', '7', '8', '9']
    b = ['1', 'jjjjjj', '3 4 5 6', '7', '8', '9']
    --------------
    Solution 2
    apres modification de a et ecriture b=a :
    a = ['1', '2', '3 4 5 6', '7', '8', '9']
    b = ['1', '2', '3 4 5 6', '7', '8', '9']
    apres b[1] = 'kkkkkk' :
    a = ['1', 'kkkkkk', '3 4 5 6', '7', '8', '9']
    b = ['1', 'kkkkkk', '3 4 5 6', '7', '8', '9']
    --------------
    Solution 2 inversee
    apres ecriture b=a et modification de b :
    a = ['1', '2', '3 4 5 6', '7', '8', '9']
    b = ['1', '2', '3 4 5 6', '7', '8', '9']
    apres b[1] = 'kkkkkk' :
    a = ['1', 'kkkkkk', '3 4 5 6', '7', '8', '9']
    b = ['1', 'kkkkkk', '3 4 5 6', '7', '8', '9']

    Pour créer une liste c qui soit une duplication de a existant réellement de façon indépendante à a. il faut écrire c = a[:]

    perso j'écrirais donc

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    a = ['1','2','3','4','5','6','7','8','9']
    b = a[:]
    b[2:-3] = [' '.join(b[2:-3])]
    print "apres creationde b :"
    print '  a =',a
    print '  b =',b
    b[1] = 'pppppp'
    print "apres  b[1] = 'pppppp' :"
    print '  a =',a
    print '  b =',b
    À noter:
    reduce() , fonction pouvant être utilisée de façon équivalente à join() dans ce cas, mais aussi dans d'autres cas ne concernant pas des chaines de caractères

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    a = ['1','2','3','4','5','6','7','8','9']
    b = a[:]
    b[2:-3] = [ reduce(lambda x,y: x+' '+y,b[2:-3]) ]
    print "Solution avec reduce() :\napres creationde b :"
    print '  a =',a
    print '  b =',b
    b[1] = 'qqqqqqq'
    print "apres  b[1] = 'qqqqqqq' :"
    print '  a =',a
    print '  b =',b

  4. #4
    Futur Membre du Club
    Profil pro
    Inscrit en
    Mars 2006
    Messages
    3
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mars 2006
    Messages : 3
    Par défaut
    Ahhh j'attendais ton intervention avec impatience eyquem (je suis le forum depuis un petit moment et tes démonstrations sont toujours très intéressantes ...)

    Alors pour le problème de pointeur de b sur a, je le savais très bien. J'ai utilisé ces 2 variables pour le problème et l'exemple. En réalité, je me fiche de b, je return directement le calcul opéré sur a.

    Par contre, je ne connaissais pas reduce j'ai lu la doc, et il permet de manipuler certes d'autres choses que des string, (notamment ajouté des int d'une liste .. et certainement plus) mais je n'en vois pas encore la portée ^^

    Encore merci pour les conseils

Discussions similaires

  1. tri de liste chainée
    Par RezzA dans le forum C
    Réponses: 7
    Dernier message: 26/01/2003, 20h25
  2. Réponses: 2
    Dernier message: 04/10/2002, 09h13
  3. liste d'objets
    Par Pierrot dans le forum Langage
    Réponses: 2
    Dernier message: 27/09/2002, 09h56
  4. Compter le nombre ligne listée (COUNT) ?
    Par StouffR dans le forum Langage SQL
    Réponses: 7
    Dernier message: 02/09/2002, 09h41
  5. Listes déroulantes liées entre elles
    Par denisC dans le forum Général JavaScript
    Réponses: 0
    Dernier message: 27/07/2002, 15h53

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