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 :

Tri de date dans une base de donnée SQlite3 [Python 3.X]


Sujet :

Python

  1. #1
    Membre averti
    Homme Profil pro
    Technicien maintenance
    Inscrit en
    Avril 2020
    Messages
    40
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 44
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Technicien maintenance
    Secteur : Aéronautique - Marine - Espace - Armement

    Informations forums :
    Inscription : Avril 2020
    Messages : 40
    Par défaut Tri de date dans une base de donnée SQlite3
    Bonjour,

    Je butes sur le moyen d'afficher dans un treeview uniquement les dates supérieures à aujourd'hui provenant d'une bas de donnée.

    J'ai fait un petit programme sortis du programme principal.

    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
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    #!/usr/bin/PYTHON
    # -*-coding:utf-8 -*
     
    import sqlite3
    from tkinter import *
    from tkinter import ttk
     
    class Pdf:
        def __init__(self):
            self.root_expired_list_part = Tk()
            self.root_expired_list_part.title("Parts Expired List")
            self.root_expired_list_part.iconbitmap("data/logo.ico")
            self.root_expired_list_part.geometry("720x350+200+100")
            self.root_expired_list_part.resizable(width=FALSE, height=FALSE)
            self.root_expired_list_part.grab_set()
     
            # Treeview
            self.tree_expired_list = ttk.Treeview(self.root_expired_list_part, columns=(1, 2), height=5, show="headings")
            self.tree_expired_list.place(width=600, height=330)
     
            # Scrollbar
            self.vsb_exp_list = ttk.Scrollbar(self.root_expired_list_part, orient="vertical", command=self.tree_expired_list.yview)
            self.vsb_exp_list.place(x=600, height=330)
            self.tree_expired_list.configure(yscrollcommand=self.vsb_exp_list.set)
            self.hsb_exp_list = ttk.Scrollbar(self.root_expired_list_part, orient="horizontal", command=self.tree_expired_list.xview)
            self.hsb_exp_list.place(y=330, width=600)
            self.tree_expired_list.configure(xscrollcommand=self.hsb_exp_list.set)
     
            # Display database expired in treeview object
            self.conn = sqlite3.connect('data/date_list.db')
            self.cursor = self.conn.cursor()
            self.select = self.cursor.execute("SELECT * FROM date ORDER BY date DESC")
            for row in self.select:
                self.tree_expired_list.insert('', END, value=row)
     
            # Create column's name & size
            # Column name
            self.tree_expired_list.heading(1, text="ID")
            self.tree_expired_list.heading(2, text="Date")
     
            # Column size
            self.tree_expired_list.column(1, width=40)
            self.tree_expired_list.column(2, width=100)
     
            conn.close()
     
            # Buttons
            self.button_cancel = ttk.Button(self.root_expired_list_part, text="Cancel", command=self.root_expired_list_part.destroy)
            self.button_cancel.place(x=630, y=305, width=80, height=35)
            self.root_expired_list_part.mainloop()
     
     
    Pdf.__call__()
    Avec ce code les dates sont affichées par ordre décroissante. Jusque là pour moi ça va ensuite c'est la que je suis perdu.

    J'aimerai affiché uniquement les dates qui sont inférieures à celle d'aujourd'hui. Je pense que ça doit se passer au niveau de la requête SQL :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    self.select = self.cursor.execute("SELECT * FROM date ORDER BY date DESC")
    il faudrait intégrer une variable avec une condition mais là je n'y arrive pas .... j'ai même pas un début. J'ai cherché partout et ai longtemps hésité à poster de peur d'être passé à coté d'une doc ou d'un tuto quelques part ...

    Bref, merci d'avance pour l'aide

  2. #2
    Membre éclairé
    Homme Profil pro
    Data Lover
    Inscrit en
    Décembre 2014
    Messages
    96
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Hauts de Seine (Île de France)

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

    Informations forums :
    Inscription : Décembre 2014
    Messages : 96
    Par défaut
    Salut,

    Selon votre requête, ça donnera un truc comme ça :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
     
    from datetime import date
    .
    .
    .
    # Récupération de la date d'aujourd'hui
    today = date.today()
     
    filtre_date = (today,)
     
    self.select = self.cursor.execute("SELECT * FROM date WHERE date <?", filtre_date)

  3. #3
    Membre averti
    Homme Profil pro
    Technicien maintenance
    Inscrit en
    Avril 2020
    Messages
    40
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 44
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Technicien maintenance
    Secteur : Aéronautique - Marine - Espace - Armement

    Informations forums :
    Inscription : Avril 2020
    Messages : 40
    Par défaut
    Super !! merci infiniment !!!

    Tellement simple en faite je sais pas pourquoi mais je cherchais absolument à mettre la condition dans une variable alors qu'il fallait la mettre dans la commande SQL ....

    Bref testé.... et fonctionne parfaitement !

    Merci encore master4

    petite question en plus : si je n'ai pas de date (donc que le champ est vide) et que je ne veux pas les afficher ?

  4. #4
    Membre prolifique
    Avatar de Sve@r
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Février 2006
    Messages
    12 828
    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 828
    Billets dans le blog
    1
    Par défaut
    Bonjour
    Citation Envoyé par Fred973 Voir le message
    petite question en plus : si je n'ai pas de date (donc que le champ est vide) et que je ne veux pas les afficher ?
    select ... and date is not null
    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]

  5. #5
    Membre averti
    Homme Profil pro
    Technicien maintenance
    Inscrit en
    Avril 2020
    Messages
    40
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 44
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Technicien maintenance
    Secteur : Aéronautique - Marine - Espace - Armement

    Informations forums :
    Inscription : Avril 2020
    Messages : 40
    Par défaut
    Merci Sve@r.

    J'ai essayé donc comme ça :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
            select = cursor.execute("SELECT due_date, shelf, description, part_number, serial_number, quantity, remarks "
                                    "FROM parts_inventory WHERE due_date <? AND due_date IS NOT null", expired_filter)
    mais pas de changement dans l'affichage et pas d'erreur non plus dans la console. J'oublie quelque chose ?

  6. #6
    Membre averti
    Homme Profil pro
    Technicien maintenance
    Inscrit en
    Avril 2020
    Messages
    40
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 44
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Technicien maintenance
    Secteur : Aéronautique - Marine - Espace - Armement

    Informations forums :
    Inscription : Avril 2020
    Messages : 40
    Par défaut
    ok j'ai trouvé mon erreur dans ma bdd les champs vides n'étaient pas inscrit en tant que "null" en sql ou "non" en python. En changement le statut des champs vides avec DB Browser tout fonctionne nickel !!

    Merci encore à tous pour votre aide énorme ! J'apprends beaucoup

    Quelqu'un aurait une doc ou un lien sur un lexique du langage SQL pour SQLite3 ?

  7. #7
    Expert éminent
    Homme Profil pro
    Architecte technique retraité
    Inscrit en
    Juin 2008
    Messages
    21 716
    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 716
    Par défaut
    Citation Envoyé par Fred973 Voir le message
    Quelqu'un aurait une doc ou un lien sur un lexique du langage SQL pour SQLite3 ?
    Vous avez tout ce qu'il faut dans la documentation officielle de sqlite.

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

  8. #8
    Membre averti
    Homme Profil pro
    Technicien maintenance
    Inscrit en
    Avril 2020
    Messages
    40
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 44
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Technicien maintenance
    Secteur : Aéronautique - Marine - Espace - Armement

    Informations forums :
    Inscription : Avril 2020
    Messages : 40
    Par défaut
    Citation Envoyé par wiztricks Voir le message
    Vous avez tout ce qu'il faut dans la documentation officielle de sqlite.

    - W
    Merci beaucoup Wiztricks exactement ce qu'il me fallait.

    Et encore merci à tous

  9. #9
    Membre prolifique
    Avatar de Sve@r
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Février 2006
    Messages
    12 828
    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 828
    Billets dans le blog
    1
    Par défaut
    Citation Envoyé par Fred973 Voir le message
    En changement le statut des champs vides avec DB Browser tout fonctionne nickel !!
    D'autant plus que la valeur "NULL" est très importante en SQL. C'est une valeur qui signifie "info inconnue". Par exemple la clause d'unicité ne prend pas en compte le NULL (on peut donc avoir plusieurs lignes ayant cette colonne à NULL même si cette colonne est protégée par une clause d'unicité). Et accessoirement "info inconnue" signifie aussi que l'info (si elle était connue) pourrait correspondre au critère (c'est pour ça que ta première requête récupérait aussi les NULL).
    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]

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

Discussions similaires

  1. Insérer une date dans une base de données Postgres
    Par sylvainkouo dans le forum JDBC
    Réponses: 1
    Dernier message: 17/01/2013, 09h44
  2. Réponses: 1
    Dernier message: 11/01/2010, 13h46
  3. enrégistrer un date dans une base de données Mysql 5
    Par Klemsy78 dans le forum Bases de données
    Réponses: 2
    Dernier message: 03/11/2009, 18h08
  4. [MySQL] Insérer une date dans une base de données
    Par agnaou dans le forum PHP & Base de données
    Réponses: 29
    Dernier message: 23/03/2009, 11h43
  5. Problème d'affichage de date dans une base de donnée
    Par Gouyon dans le forum C++Builder
    Réponses: 7
    Dernier message: 11/04/2007, 07h57

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