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 :

Comment formater l'affichage lorsqu'on utilise une procédure stockée [Python 3.X]


Sujet :

Python

  1. #1
    Membre à l'essai
    Profil pro
    Inscrit en
    Novembre 2004
    Messages
    11
    Détails du profil
    Informations personnelles :
    Localisation : Canada

    Informations forums :
    Inscription : Novembre 2004
    Messages : 11
    Points : 13
    Points
    13
    Par défaut Comment formater l'affichage lorsqu'on utilise une procédure stockée
    Bonjour.

    Avec des extensions, je peux mettre en forme le résultat d'une requête, par contre, lorsque j'utilise des procédures stockées je n'arrive pas à formater l'affichage du résultat.
    Je suis en mode console avec VS Code.

    Voici le code que j'utilise pour l'affichage:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
        cursor.callproc('getclient')    
        for result in cursor.stored_results():
            print (result.fetchall())
    Voici le résultat :
    [('CL56', 'Oscar', 'Meier', 'Quai du Mont-Blanc 5, 1201 Genève, Suisse', '+41-(022) 732 61 73', 'Appartement', Decimal('350.00')), ('CL62', 'Marie', 'Labonté', '186 boul. Laviolette, Trois-Rivières J7K 3L8', '+1-(819) 524-1875', 'Appartement', Decimal('600.00')), ('CL74', 'Michel', 'Richard', 'Rue de Genève 125, 1226 Thônex, Suisse', '+41-(022) 349 34 79', 'Maison', Decimal('750.00')), ('CL76', 'Jean', 'Martin', '56 Bd St-Germain, 75000 - Paris', '+33-(01) 67 75 92 12', 'Appartement', Decimal('425.00'))]

    Avec cette commande:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
       print(type(cursor.stored_results))
    J'obtiens le type de retour : <class 'method'> et voilà ma question : Comment formater ce type de données pour être en mesure de l'afficher comment l'exemple plus bas.


    Et j'aimerais quelque chose du genre :
    +-----------+-------------------+------------------+----------------------------------------------+----------------------+----------------------+---------------------+
    | client_id | client_first_name | client_last_name | client_address | client_tel | client_prefered_type | client_max_location |
    +-----------+-------------------+------------------+----------------------------------------------+----------------------+----------------------+---------------------+
    | CL56 | Oscar | Meier | Quai du Mont-Blanc 5, 1201 Genève, Suisse | +41-(022) 732 61 73 | Appartement | 350.00 |
    | CL62 | Marie | Labonté | 186 boul. Laviolette, Trois-Rivières J7K 3L8 | +1-(819) 524-1875 | Appartement | 600.00 |
    | CL74 | Michel | Richard | Rue de Genève 125, 1226 Thônex, Suisse | +41-(022) 349 34 79 | Maison | 750.00 |
    | CL76 | Jean | Martin | 56 Bd St-Germain, 75000 - Paris | +33-(01) 67 75 92 12 | Appartement | 425.00 |
    +-----------+-------------------+------------------+----------------------------------------------+----------------------+----------------------+---------------------+

    Merci,
    Nancy

  2. #2
    Expert éminent sénior
    Avatar de Sve@r
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Février 2006
    Messages
    12 690
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Oise (Picardie)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : Aéronautique - Marine - Espace - Armement

    Informations forums :
    Inscription : Février 2006
    Messages : 12 690
    Points : 30 984
    Points
    30 984
    Billets dans le blog
    1
    Par défaut
    Bonjour
    Citation Envoyé par nancyasp Voir le message
    Voici le code que j'utilise pour l'affichage:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
        cursor.callproc('getclient')    
        for result in cursor.stored_results():
            print (result.fetchall())
    Voici le résultat :
    [('CL56', 'Oscar', 'Meier', 'Quai du Mont-Blanc 5, 1201 Genève, Suisse', '+41-(022) 732 61 73', 'Appartement', Decimal('350.00')), ('CL62', 'Marie', 'Labonté', '186 boul. Laviolette, Trois-Rivières J7K 3L8', '+1-(819) 524-1875', 'Appartement', Decimal('600.00')), ('CL74', 'Michel', 'Richard', 'Rue de Genève 125, 1226 Thônex, Suisse', '+41-(022) 349 34 79', 'Maison', Decimal('750.00')), ('CL76', 'Jean', 'Martin', '56 Bd St-Germain, 75000 - Paris', '+33-(01) 67 75 92 12', 'Appartement', Decimal('425.00'))]

    Avec cette commande:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
       print(type(cursor.stored_results))
    J'obtiens le type de retour : <class 'method'> et voilà ma question : Comment formater ce type de données pour être en mesure de l'afficher
    fetchall() retourne une liste de lignes. Donc en bouclant dessus, tu auras chaque ligne une à une..
    Ensuite une ligne c'est une liste d'infos (une info par colonne). Donc là aussi une boucle te permettra de traiter chaque colonne de la ligne.
    Mon Tutoriel sur la programmation «Python»
    Mon Tutoriel sur la programmation «Shell»
    Sinon il y en a pleins d'autres. N'oubliez pas non plus les différentes faq disponibles sur ce site
    Et on poste ses codes entre balises [code] et [/code]

  3. #3
    Membre du Club
    Homme Profil pro
    Ingénieur Système
    Inscrit en
    Novembre 2019
    Messages
    17
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 48
    Localisation : France, Mayenne (Pays de la Loire)

    Informations professionnelles :
    Activité : Ingénieur Système

    Informations forums :
    Inscription : Novembre 2019
    Messages : 17
    Points : 42
    Points
    42
    Par défaut
    Bonjour,

    Le module tabulate permet de faire des choses assez sympa rapidement.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    print(tabulate(result.fetchall(), tablefmt="pretty"))
    devrait donner qqs chose comme ça.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
     
    +------+--------+---------+----------------------------------------------+----------------------+-------------+--------+
    | CL56 | Oscar  |  Meier  |  Quai du Mont-Blanc 5, 1201 Genève, Suisse   | +41-(022) 732 61 73  | Appartement | 350.00 |
    | CL62 | Marie  | Labonté | 186 boul. Laviolette, Trois-Rivières J7K 3L8 |  +1-(819) 524-1875   | Appartement | 600.00 |
    | CL74 | Michel | Richard |    Rue de Genève 125, 1226 Thônex, Suisse    | +41-(022) 349 34 79  |   Maison    | 750.00 |
    | CL76 |  Jean  | Martin  |       56 Bd St-Germain, 75000 - Paris        | +33-(01) 67 75 92 12 | Appartement | 425.00 |
    +------+--------+---------+----------------------------------------------+----------------------+-------------+--------+
    l y a différents formats de tableaux possible. On peut également ajouter un header. Tout est très bien expliqué en suivant le lien Pypi cité + haut.

    A+

  4. #4
    Membre à l'essai
    Profil pro
    Inscrit en
    Novembre 2004
    Messages
    11
    Détails du profil
    Informations personnelles :
    Localisation : Canada

    Informations forums :
    Inscription : Novembre 2004
    Messages : 11
    Points : 13
    Points
    13
    Par défaut
    Citation Envoyé par AznarAkeba Voir le message
    Bonjour,

    Le module tabulate permet de faire des choses assez sympa rapidement.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    print(tabulate(result.fetchall(), tablefmt="pretty"))
    devrait donner qqs chose comme ça.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
     
    +------+--------+---------+----------------------------------------------+----------------------+-------------+--------+
    | CL56 | Oscar  |  Meier  |  Quai du Mont-Blanc 5, 1201 Genève, Suisse   | +41-(022) 732 61 73  | Appartement | 350.00 |
    | CL62 | Marie  | Labonté | 186 boul. Laviolette, Trois-Rivières J7K 3L8 |  +1-(819) 524-1875   | Appartement | 600.00 |
    | CL74 | Michel | Richard |    Rue de Genève 125, 1226 Thônex, Suisse    | +41-(022) 349 34 79  |   Maison    | 750.00 |
    | CL76 |  Jean  | Martin  |       56 Bd St-Germain, 75000 - Paris        | +33-(01) 67 75 92 12 | Appartement | 425.00 |
    +------+--------+---------+----------------------------------------------+----------------------+-------------+--------+
    l y a différents formats de tableaux possible. On peut également ajouter un header. Tout est très bien expliqué en suivant le lien Pypi cité + haut.

    A+
    Malheureusement, ça ne fonctionne pas. Tabulate fonctionne bien avec les requêtes. Je cherche toujours pour les procédures stockées. Les résultats sont placés dans un
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    cursor.stored_results()
    et cette ligne
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    print(tabulate(result.fetchall(), tablefmt="pretty"))
    ne fonctionne pas même en modifiant "result".

    Merci

  5. #5
    Membre à l'essai
    Profil pro
    Inscrit en
    Novembre 2004
    Messages
    11
    Détails du profil
    Informations personnelles :
    Localisation : Canada

    Informations forums :
    Inscription : Novembre 2004
    Messages : 11
    Points : 13
    Points
    13
    Par défaut
    Citation Envoyé par AznarAkeba Voir le message
    Bonjour,

    Le module tabulate permet de faire des choses assez sympa rapidement.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    print(tabulate(result.fetchall(), tablefmt="pretty"))
    devrait donner qqs chose comme ça.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
     
    +------+--------+---------+----------------------------------------------+----------------------+-------------+--------+
    | CL56 | Oscar  |  Meier  |  Quai du Mont-Blanc 5, 1201 Genève, Suisse   | +41-(022) 732 61 73  | Appartement | 350.00 |
    | CL62 | Marie  | Labonté | 186 boul. Laviolette, Trois-Rivières J7K 3L8 |  +1-(819) 524-1875   | Appartement | 600.00 |
    | CL74 | Michel | Richard |    Rue de Genève 125, 1226 Thônex, Suisse    | +41-(022) 349 34 79  |   Maison    | 750.00 |
    | CL76 |  Jean  | Martin  |       56 Bd St-Germain, 75000 - Paris        | +33-(01) 67 75 92 12 | Appartement | 425.00 |
    +------+--------+---------+----------------------------------------------+----------------------+-------------+--------+
    l y a différents formats de tableaux possible. On peut également ajouter un header. Tout est très bien expliqué en suivant le lien Pypi cité + haut.

    A+

    MERCI, MERCI

    Après plusieurs essais, j'ai réussi.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    cursor.callproc('getclient') 
        results = cursor.fetchall()
     
        for result in cursor.stored_results():
            print(tabulate(result.fetchall(), tablefmt="pretty"))
    Merci pour votre aide.
    Nancy

  6. #6
    Membre habitué
    Homme Profil pro
    Animateur Numérique
    Inscrit en
    Février 2013
    Messages
    131
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Animateur Numérique
    Secteur : Arts - Culture

    Informations forums :
    Inscription : Février 2013
    Messages : 131
    Points : 186
    Points
    186
    Par défaut
    Citation Envoyé par nancyasp Voir le message
    Malheureusement, ça ne fonctionne pas. Tabulate fonctionne bien avec les requêtes. Je cherche toujours pour les procédures stockées. Les résultats sont placés dans un
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    cursor.stored_results()
    et cette ligne
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    print(tabulate(result.fetchall(), tablefmt="pretty"))
    ne fonctionne pas même en modifiant "result".

    Merci
    Salut,

    As-tu un message d'erreur car si :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    print (result.fetchall())
    affiche une liste de tuples, ça équivaut à :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
     
    from decimal import Decimal
    from tabulate import tabulate
     
    datas = [('CL56', 'Oscar', 'Meier', 'Quai du Mont-Blanc 5, 1201 Genève, Suisse', '+41-(022) 732 61 73', 'Appartement', Decimal('350.00')), ('CL62', 'Marie', 'Labonté', '186 boul. Laviolette, Trois-Rivières J7K 3L8', '+1-(819) 524-1875', 'Appartement', Decimal('600.00')), ('CL74', 'Michel', 'Richard', 'Rue de Genève 125, 1226 Thônex, Suisse', '+41-(022) 349 34 79', 'Maison', Decimal('750.00')), ('CL76', 'Jean', 'Martin', '56 Bd St-Germain, 75000 - Paris', '+33-(01) 67 75 92 12', 'Appartement', Decimal('425.00'))]
     
    print(tabulate(datas, tablefmt="pretty"))
    resultat :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
     
    +------+--------+---------+----------------------------------------------+----------------------+-------------+--------+
    | CL56 | Oscar  |  Meier  |  Quai du Mont-Blanc 5, 1201 Genève, Suisse   | +41-(022) 732 61 73  | Appartement | 350.00 |
    | CL62 | Marie  | Labonté | 186 boul. Laviolette, Trois-Rivières J7K 3L8 |  +1-(819) 524-1875   | Appartement | 600.00 |
    | CL74 | Michel | Richard |    Rue de Genève 125, 1226 Thônex, Suisse    | +41-(022) 349 34 79  |   Maison    | 750.00 |
    | CL76 |  Jean  | Martin  |       56 Bd St-Germain, 75000 - Paris        | +33-(01) 67 75 92 12 | Appartement | 425.00 |
    +------+--------+---------+----------------------------------------------+----------------------+-------------+--------+

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

Discussions similaires

  1. TfileInputXml et Tmap comment filtrer en utilisant une procédure stockée
    Par 404error dans le forum Développement de jobs
    Réponses: 0
    Dernier message: 29/08/2016, 16h13
  2. Utiliser une procédure stockée Oracle
    Par jsd03 dans le forum Développement de jobs
    Réponses: 0
    Dernier message: 18/08/2008, 16h45
  3. [Divers] Peut-on utiliser une procédure stockée dans Crystal ?
    Par noumian dans le forum SAP Crystal Reports
    Réponses: 0
    Dernier message: 19/06/2008, 21h50
  4. Utiliser une procédure stockée dnas Framework C8
    Par Darcynette dans le forum Cognos
    Réponses: 4
    Dernier message: 14/12/2007, 19h22
  5. Format de données en sortie d'une procédure stockée
    Par Martin Sylvie dans le forum MS SQL Server
    Réponses: 2
    Dernier message: 22/02/2005, 12h02

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