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 :

pointeur sur une string ?


Sujet :

Python

  1. #1
    Membre éprouvé Avatar de awalter1
    Inscrit en
    Août 2004
    Messages
    994
    Détails du profil
    Informations forums :
    Inscription : Août 2004
    Messages : 994
    Par défaut pointeur sur une string ?
    Bonjour,
    Je trouve dans une appli python le code suivant :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    def pPrint(*str):
    	tmp_str=""
    	for s in str:
    		tmp_str = tmp_str+s
    	print tmp_str
    Quel est le sens du * dans l'argument de pPrint ? Est ce la même chose qu'en C ?
    Merci

  2. #2
    Expert éminent
    Homme Profil pro
    Architecte technique retraité
    Inscrit en
    Juin 2008
    Messages
    21 696
    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 696
    Par défaut
    Salut,
    Ce n'est pas un pointeur, c'est une forme générique pour dire que la fonction accepte une liste quelconque d'arguments.
    Exemple, soit
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    def f(a, b, c):
         'une fonction qui admet 3 arguments'
    Imaginons une fonction g qui soit passe plat vers f, style:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    def g(*args, **kwds):
         return f(*args, **kwds)
    g ne connait pas la signature de f.
    - W
    Architectures post-modernes.
    Python sur DVP c'est aussi des FAQs, des cours et tutoriels

  3. #3
    Membre très actif
    Avatar de afranck64
    Homme Profil pro
    Étudiant
    Inscrit en
    Janvier 2009
    Messages
    592
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 33
    Localisation : Cameroun

    Informations professionnelles :
    Activité : Étudiant
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Janvier 2009
    Messages : 592
    Par défaut
    Bonjour,
    Et pour ce qui est du "**" C est pour dire que la fonction prend egalement en parametre un nombre indetermine de parametres de la formeDonc, pour une fonction g de la forme:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    def g(*args, **kwds):
        print (args, kwds)
    tu peux avoir les appels:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    g()
    g(1,2,3)
    g("hello world", value=1024)
    Win 10 64 bits / Linux Mint 18, - AMD A6 Quad: Py27 / Py35
    CONTENU D'UNE QUESTION
    Exemples:
    - Configuration (système d'exploitation, version de Python et des bibliothèques utilisées)
    - Code source du morceau de programme où il y a un bogue
    - Ligne de code sur laquelle le bogue apparaît
    - Erreur complète retournée pas l'interpréteur Python
    - Recherche déjà effectuée (FAQ, Tutoriels, ...)
    - Tests déjà effectués

  4. #4
    Membre éprouvé
    Avatar de Luke spywoker
    Homme Profil pro
    Etudiant informatique autodidacte
    Inscrit en
    Juin 2010
    Messages
    1 077
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Etudiant informatique autodidacte

    Informations forums :
    Inscription : Juin 2010
    Messages : 1 077
    Par défaut
    Petite question:
    Je connait *args qui signifie tous nombre et tous type d'arguments.
    on pourrait traduire par: '*(joker: remplace tout)' + 'args(arguments)'
    mais que signifie **kwds:
    le ** ?
    et surement: keywords ?
    Excuser la petite incursion.

    Ne serait il pas plus logique d'employer une syntaxe avec:
    -un * pour le nombre d'arguments et
    -un autre * pour tous types d'arguments.

  5. #5
    Expert éminent
    Homme Profil pro
    Architecte technique retraité
    Inscrit en
    Juin 2008
    Messages
    21 696
    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 696
    Par défaut
    Salut,

    Un callable Python accepte des paramètres positionnels (une liste de...) et des paramètres nommés (i.e. des paires clés/valeurs).

    On peut mixer les choses, i.e. le prototype d'un callable pourrait très bien être:
    f(a, b, *rest, c=False, **others_kwds)
    i.e. on veut que l'appelant donne au moins a, b, on verra pour *rest.

    c=False permet de donner une valeur par défaut à c et de ne pas obliger l'appelant à... quand à others_kwds rien n'est imposé dans le prototype: ce n'est que plus tard (après l'appel) qu'on s'en inquiétera.

    Le tutoriel livré avec la doc de Python raconte cela très bien et donne quelque cas pratique d'utilisation intéressantes de cela.

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

  6. #6
    Membre Expert Avatar de PauseKawa
    Homme Profil pro
    Technicien Help Desk, maintenance, réseau, système et +
    Inscrit en
    Juin 2006
    Messages
    2 725
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Hérault (Languedoc Roussillon)

    Informations professionnelles :
    Activité : Technicien Help Desk, maintenance, réseau, système et +
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Juin 2006
    Messages : 2 725
    Par défaut
    Bonjour,

    L'erreur n'étant pas toujours compréhensible d'un premier abord(1), et n'ayant pas vu l'information dans le lien, je préciserai que les paramètres 'voulus' doivent précédés les optionnels. Le c=False doit précéder le tuple *rest(2).
    A noter l'Important warning: The default value is evaluated only once' de 4.7.1. Default Argument Values. L'exemple de L=[] me semble bien fait.

    Bon code

    (1)
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    >>> def test(*args, value):
      File "<stdin>", line 1
        def test(*args, value):
                            ^
    SyntaxError: invalid syntax
    (2)
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    >>> def f(a, b, *rest, c=False, **others_kwds):
      File "<stdin>", line 1
        def f(a, b, *rest, c=False, **others_kwds):
                           ^
    SyntaxError: invalid syntax
    >>> def f(a, b, c=False, *rest, **others_kwds):
    ...

  7. #7
    Expert éminent
    Homme Profil pro
    Architecte technique retraité
    Inscrit en
    Juin 2008
    Messages
    21 696
    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 696
    Par défaut
    Très juste: c=False reste un paramètre "positionnel" et doit donc être placé avant le *rest. Je me fais toujours avoir parce que les règles de composition sont surprenantes:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    def spam(a, b=False, c='a', **kwds):
        print 'a = %s, b = %s, c = %s, kwds= %s' % (a, b, c, kwds)
     
    def jam(a, **kwds):
        print 'a = %s, kwds= %s' % (a, kwds)
        spam(a, **kwds)
     
    jam(1, c='d', x='e')
    affiche: a = 1, b = False, c = d, kwds= {'x': 'e'}
    i.e. les paramètres nommés sont "positionnels" ou "instanciables" en fonction du dict passé par l'appelant.

    Le 'ou' est parce que spam(1, True, 'd', b=False) râle:
    TypeError: spam() got multiple values for keyword argument 'b'
    Normal, il faut savoir ce qu'on veut...

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

  8. #8
    Membre éprouvé Avatar de awalter1
    Inscrit en
    Août 2004
    Messages
    994
    Détails du profil
    Informations forums :
    Inscription : Août 2004
    Messages : 994
    Par défaut
    Merci de ces explications très argumentées.

  9. #9
    Membre Expert Avatar de plxpy
    Homme Profil pro
    Ingénieur géographe
    Inscrit en
    Janvier 2009
    Messages
    792
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 60
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Ingénieur géographe
    Secteur : Aéronautique - Marine - Espace - Armement

    Informations forums :
    Inscription : Janvier 2009
    Messages : 792
    Par défaut
    Bonjour,

    J'exhume cette discussion, même taggée "Résolu", parce qu'un point qui me semble important n'a pas été (ou partiellement) abordé : celui de l'appel de ces fonctions (celles avec du '*args' ou '**kwd').

    Les seuls exemples que j'ai vus sont des exemples où le nombre d'arguments ou de couples (clé,valeur) est connu au moment du codage. Personnellement, j'utilise assez régulièrement ces fonctions et construis dynamiquement les arguments que je passe effectivement à la fonction.

    Pour les '*args' : on peut contstruire une liste/un tuple et appeler une fonction en réutilisant ce formalisme '*args'. Exemple (inutile mais didactique) d'un script qui concatène les arguments (autres que le nom du script) et affiche le résultat :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
     
    import sys
     
    def concatener(*args):
        # args est de type tuple
        return ' puis '.join(args)
     
    vrais_arguments = sys.argv[1:]
    print concatener(*vrais_arguments)
    donne

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
     
    plx@sony:~$ python2.6 concatener.py un deux trois quatre
    un puis deux puis trois puis quatre
    Cette fois-ci pour **kwd (très utile, par exemple, pour des données organisées en "colonnes", dont on ne connait ni le nombre, ni les "noms"). Dans l'exemple ci-dessous, je récupère les noms de colonnes depuis la ligne de commande et leur associe leur "rang" (de 0 à ...)

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
     
    import sys
     
    def artificiel(**kwd):
        for k,v in kwd.items():
            print "cle %s valeur %d" % (k,v)
     
    dico = dict()
    for a,arg in enumerate(sys.argv[1:]):
        dico[arg] = a
     
    artificiel(**dico)
    donne :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
     
    plx@sony:~$ python2.6 dico.py nom prenom age adresse
    cle nom valeur 0
    cle age valeur 2
    cle adresse valeur 3
    cle prenom valeur 1
    Là, pour le coup, les clés doivent obligatoirement être des chaines de caractères.

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

Discussions similaires

  1. Pointeur sur une string
    Par mk_____ dans le forum C++
    Réponses: 5
    Dernier message: 10/06/2010, 12h30
  2. Pointeur sur une chaine de caractère string
    Par Lucier dans le forum C#
    Réponses: 9
    Dernier message: 17/03/2010, 14h22
  3. Réponses: 14
    Dernier message: 14/03/2005, 09h16
  4. Probleme de pointeur sur une fonction
    Par nicky78 dans le forum C
    Réponses: 2
    Dernier message: 23/05/2004, 20h26
  5. [MFC] Problème pointeur sur une classe
    Par mick74 dans le forum MFC
    Réponses: 7
    Dernier message: 14/04/2004, 14h17

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