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 :

Récupérer la première valeur de ma requête


Sujet :

Python

  1. #1
    Membre du Club
    Profil pro
    Inscrit en
    Janvier 2010
    Messages
    53
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2010
    Messages : 53
    Points : 40
    Points
    40
    Par défaut Récupérer la première valeur de ma requête
    Bonjour à tous,

    je fais un script python qui me permet d'afficher sur mon serveur apache le résultat de requêtes SQL, seulement lorsque j'affiche le résultat d'une requête il me manque toujours le 1er résultat (en comparaison aux résultats obtenus dans mon terminal).

    Voici un extrait de mon code :
    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
     
     try : 
            cur.execute("select nom,public.famille.numfamille,taillefamille from public.famille, public.gene  where public.famille.numfamille = public.gene.numfamille and  public.famille.numfamille="+str(numfamille))
        except Exception, e:
            print e
     
        row = cur.fetchone()
     
        print "Cette famille est de taille :"+str(row['taillefamille']);
        print "<br>"
        print "Voici les genes appartenant a cette famille :"
        print "<TABLE border=1>"
        for row in cur:
            print "<TR>"
    	print "<td>"
            print ""+str(row['nom']);
    	print "</td>"
            print "</TR>"

    Lorsque j'affiche le nom des gènes il me manque toujours le premier nom trouvé par ma requêtes, auriez vous une idée ?
    En fait j'arrive à récupérer cette valeur mais en faisant un print supplémentaire à l'exterieur de la boucle, n'y aurait'il pas une autre méthode que :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
     
      row = cur.fetchone()
     
        print "Cette famille est de taille :"+str(row['taillefamille']);
        print ""+str(row['nom']);
        print "<br>"
        print "Voici les genes appartenant a cette famille :"
        print "<TABLE border=1>"
        print "<TR>"
        print "<td>"
        print ""+str(row['nom']);
        print "</td>"
        print "</TR>

    Merci à vous

  2. #2
    Membre averti
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Mai 2011
    Messages
    180
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Belgique

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : Conseil

    Informations forums :
    Inscription : Mai 2011
    Messages : 180
    Points : 321
    Points
    321
    Par défaut
    Salut,


    Il est normal que, en faisant quelque chose comme
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
     
    row = curs.fetchone(
    # ....
    for row in curs:
        print row[0] # Par exemple
    tu n'aies plus que N-1 lignes retournées par l'itération. En effet, curs.fetchone()
    en "consomme" une.

    Si tu veux grader toute les lignes, un bon truc est d'utiliser
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     
    result=curs.fetchall() # result est une liste
    print u"La taille de la famille est %d" % result[0]['taillefamille']
    #ensuite, tu parcours normalement result.
    Sur ce, si la taille de la famille est définie par le nombre de gênes qui la composent, tu peux faire ainsi
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    print u"La taille de la famille est %d" % len(result)
    et le tour est joué !

    A bientôt !

Discussions similaires

  1. [Firebird]Récupérer qu'une valeur d'une requête SQL
    Par Patrick25300 dans le forum Bases de données
    Réponses: 3
    Dernier message: 02/02/2013, 14h56
  2. Récupérer la valeur d'une requête
    Par Gabout dans le forum Requêtes et SQL.
    Réponses: 4
    Dernier message: 09/05/2008, 08h29
  3. Récupérer les valeurs d'une requête SQL dans un champs html SELECT
    Par tamiii dans le forum Général JavaScript
    Réponses: 1
    Dernier message: 10/11/2007, 13h27
  4. Réponses: 2
    Dernier message: 12/06/2007, 08h08
  5. [Débutant] comment récupérer la valeur d'une requête?
    Par Athorus dans le forum Servlets/JSP
    Réponses: 1
    Dernier message: 27/02/2007, 17h59

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