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 une variable d'un autre script


Sujet :

Python

  1. #1
    Membre actif
    Homme Profil pro
    Architecte matériel
    Inscrit en
    Juin 2014
    Messages
    18
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 35
    Localisation : Tunisie

    Informations professionnelles :
    Activité : Architecte matériel
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Juin 2014
    Messages : 18
    Par défaut récupérer une variable d'un autre script
    Bonjour tout le monde,

    J'aurai besoin d'un peu d'aide s'il vous plait sur un problème sur lequel je bloque.

    En fait, j'utilise plusieurs script et un classe dans chacun de ses scripts.
    Au niveau du 3éme script "créerDossier", il y a un formulaire patient qui s'enregistre sur MySQL, donc, une fois un patient sélectionné via son ID, je clique sur un bouton "ouvrir dossier" qui me mène au 4éme script "dossierPatient".

    Le problème c'est que je n'arrive pas récupérer l'ID du 3éme script dans le 4éme script pour ouvrir la base de donnée relative au dit-patient.

    J'ai bien sur chercher sur le net, j'ai utilisé la méthode qui m'a semblé correcte, qui est la suivant.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
     
    import creerDossier
     
    f1 = creerDossier.PageTwo(self, parent)
                f2 =f1.searchDB(id)
    mais j'ai comme erreur :
    AttributeError: 'PageTwo' object has no attribute 'searchDB'


    Alors je vais partager avec vous mon code (raccourci), peut être que vous pourrez m'aider:

    script 1 : le root:

    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
    54
    55
    56
    57
    58
    59
    60
    61
    62
    63
    64
    65
    66
    67
    68
    69
    70
    71
    72
    73
    74
    75
    76
    77
    78
    79
    80
     
    import tkinter as tk                # python 3
    from tkinter import messagebox
    from chercherDossier import PageOne
    from creerDossier import PageTwo
    from dossierPatient import PageThree
     
     
    class SampleApp(tk.Tk):
     
        def __init__(self, *args, **kwargs):
            tk.Tk.__init__(self, *args, **kwargs)
     
            self.title_font = tkfont.Font(family='Helvetica', size=18, weight="bold", slant="italic")
            self.state("zoomed")
            self.iconbitmap("image/leH.ico")
            self.title("HERMES")
            # the container is where we'll stack a bunch of frames
            # on top of each other, then the one we want visible
            # will be raised above the others
            container = tk.Frame(self)
            container.pack(side="top", fill="both", expand=True)
            container.grid_rowconfigure(0, weight=1)
            container.grid_columnconfigure(0, weight=1)
     
            self.frames = {}
            for F in (StartPage, PageOne, PageTwo, PageThree):
                page_name = F.__name__
                frame = F(parent=container, controller=self)
                self.frames[page_name] = frame
     
                # put all of the pages in the same location;
                # the one on the top of the stacking order
                # will be the one that is visible.
                frame.grid(row=0, column=0, sticky="nsew")
     
            self.show_frame("StartPage")
     
        def show_frame(self, page_name):
            '''Show a frame for the given page name'''
            frame = self.frames[page_name]
            frame.tkraise()
     
     
    class StartPage(tk.Frame):
     
        def __init__(self, parent, controller):
            tk.Frame.__init__(self, parent)
            self.controller = controller
     
            def ok():
                uname = e1.get()
                password = e2.get()
     
                if (uname == "" and password == ""):
                    messagebox.showinfo("", "Blank Not allowed")
     
                elif (uname == "admin" and password == "admin"):
                    messagebox.showinfo("", "Login Success")
                    controller.show_frame("PageOne")
     
                else:
                    messagebox.showinfo("", "Incorrent Username and Password")
     
            user = tk.Label(self, text="UserName").grid(row=0, column=0)
            password = tk.Label(self, text="Password").grid(row=1, column=0)
     
            e1 = tk.Entry(self)
            e1.grid(row=0, column=1)
     
            e2 = tk.Entry(self)
            e2.grid(row=1, column=1)
            e2.config(show="*")
     
            frame1_btn = tk.Button(self, text="Login", command=ok, height=3, width=13).grid(row=2, column=1)
     
     
    if __name__ == "__main__":
        app = SampleApp()
        app.mainloop()
    script numéro 3 : creerDossier (le 2 n'étant pas pertienent):

    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
    54
    55
    56
    57
    58
    59
    60
    61
    62
    63
    64
    65
    66
    67
    68
    69
    70
    71
    72
    73
    74
    75
    76
    77
    78
    79
    80
    81
    82
    83
    84
    85
    86
    87
    88
    89
    90
    91
    92
    93
    94
    95
    96
    97
    98
    99
    100
    101
    102
    103
    104
    105
    106
    107
    108
    109
    110
    111
    112
    113
    114
    115
    116
    117
    118
    119
    120
    121
    122
    123
    124
    125
    126
    127
    128
    129
    130
    131
    132
    133
    134
    135
    136
    137
    138
    139
    140
    141
    142
    143
    144
    145
    146
    147
    148
    149
    150
    151
    152
    153
    154
    155
    156
    157
    158
    159
    160
    161
    162
    163
     
    import mysql.connector
    from tkinter import *
    import tkinter as tk                # python 3
    from tkinter import ttk, messagebox
    import tkinterpp
     
     
    class PageTwo(tk.Frame):
     
        def __init__(self, parent, controller):
            tk.Frame.__init__(self, parent)
            self.controller = controller
     
     
            mysqldb = mysql.connector.connect(
                host='localhost',
                user='root',
                password='*****',
                port='3306',
                database='hermes_sql'
            )
            mycursor = mysqldb.cursor()
     
            def GetValue(event):
                ematricule.delete(0, END)
                enom.delete(0, END)
                eprenom.delete(0, END)
     
                row_id = listBox.selection()[0]
                select = listBox.set(row_id)
     
                ematricule.insert(0, select['id'])
                enom.insert(0, select['nom'])
                eprenom.insert(0, select['prenom'])
     
            def Add():
                nom = enom.get()
                prenom = eprenom.get()
     
                mysqldb = mysql.connector.connect(
                    host='localhost',
                    user='root',
                    password='*****',
                    port='3306',
                    database='hermes_sql'
                )
                mycursor = mysqldb.cursor()
     
                try:
                    sql = "INSERT INTO  users (id,nom,prenom) " \
                          "VALUES (%s,%s, %s)"
                    val = (0, nom, prenom)
                    mycursor.execute(sql, val)
                    mysqldb.commit()
                    lastid = mycursor.lastrowid
                    ematricule.delete(0, END)
                    ematricule.insert(END, lastid)
     
                    messagebox.showinfo("information", "Employee inserted successfully...")
     
                    ematricule.delete(0, END)
                    enom.delete(0, END)
                    eprenom.delete(0, END)
     
                    enom.focus_set()
                except Exception as e:
                    print(e)
                    mysqldb.rollback()
                    mysqldb.close()
     
     
            def searchDB():
                id = ematricule.get()
                mysqldb = mysql.connector.connect(
                    host='localhost',
                    user='root',
                    password='*****',
                    port='3306',
                    database='hermes_sql'
                )
                mycursor = mysqldb.cursor()
     
                try:
                    sql = "select * from users where id = %s"
                    val = (id,)
                    mycursor.execute(sql, val)
                    users = mycursor.fetchone()
                    ematricule.delete(0, END)
                    enom.delete(0, END)
                    eprenom.delete(0, END)
     
                    enom.focus_set()
                    ematricule.insert(0,  str(users[0]))
                    enom.insert(0,  str(users[1]))
                    eprenom.insert(0,  str(users[2]))
     
     
                except Exception as e:
                    print(e)
                    mysqldb.rollback()
                    mysqldb.close()
     
                return id
     
            def vider_entry():
                ematricule.delete(0, END)
                enom.delete(0, END)
                eprenom.delete(0, END)
     
     
            def show():
                mycursor.execute("SELECT id,nom,prenom FROM users")
                users = mycursor.fetchall()
                print(users)
     
                for i, (id, nom, prenom) in enumerate(users, start=1):
                    listBox.insert("", "end", values=(id,nom,prenom))
                    mysqldb.close()
     
            global ematricule
            global enom
            global eprenom
     
     
            # creer frame pour identifiant
            frame_ident = Frame(self, bg="#F5CBA7", bd=1, relief=SUNKEN)
            frame_ident.pack(fill=X)
     
     
            lmatricule = tk.Label(frame_ident, text="matricule", bg="#F5CBA7").grid(row=2, column=0)
            ematricule = tk.Entry(frame_ident)
            ematricule.grid(row=2, column=1)
            lnom = Label(frame_ident, text="nom", bg="#F5CBA7").grid(row=3, column=0)
            enom = tk.Entry(frame_ident)
            enom.grid(row=3, column=1)
            lprenom = tk.Label(frame_ident, text="prenom", bg="#F5CBA7").grid(row=3, column=2)
            eprenom = tk.Entry(frame_ident)
            eprenom.grid(row=3, column=3)
     
     
            # frame pout les bouttons
            frame_butt = Frame(self, bg="#F5CBA7", bd=1, relief=SUNKEN)
            frame_butt.pack(fill=X, pady=10)
     
            Button(frame_butt, text="créer dossier", command=Add, height=3, width=13).grid(row=0, column=0, padx=20)
            Button(frame_butt, text="chercher", command=searchDB, height=3, width=13).grid(row=0, column=3, padx=20)
            Button(frame_butt, text="ouvrir le dossier",command=lambda: controller.show_frame("PageThree"), height=3, width=13).grid(row=0, column=5, padx=20)
     
            # frame tableau
            frame_tab = Frame(self, bg="#F5CBA7", bd=1, relief=SUNKEN)
            frame_tab.pack(fill=X, pady=10)
     
            cols = ('id', 'nom', 'prenom', 'date de naissance', 'sex', 'pays', 'ville', 'code postal', 'adresse','numèro de telephone', 'adresse mail')
            listBox = ttk.Treeview(frame_tab, columns=cols, show='headings', selectmode='browse')
     
     
            for col in cols:
                listBox.heading(col, text=col)
                listBox.grid(row=1, column=0, columnspan=3)
     
            show()
            listBox.bind('<Double-Button-1>', GetValue)
    et le script 4 : dossierPatient, ou j'essaye de récupérer l'ID de la fonction "def searchDB():" de la classe "class PageTwo(tk.Frame):"

    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
    54
    55
    56
    57
    58
    59
    60
    61
    62
    63
    64
    65
    66
    67
    68
    69
    70
    71
    72
     
    import mysql.connector
    from tkinter import *
    import tkinter as tk
    import creerDossier
     
     
    class PageThree(tk.Frame):
        def __init__(self, parent, controller):
            tk.Frame.__init__(self, parent)
            self.controller = controller
     
     
            def lookDB():
                  #ici le problème####################le problème #####################################
                f1 = creerDossier.PageTwo(self, parent)
                f2 =f1.searchDB(id)
                id = f2
                   ####################################################################
                mysqldb = mysql.connector.connect(
                    host='localhost',
                    user='root',
                    password='****',
                    port='3306',
                    database='hermes_sql'
                )
                mycursor = mysqldb.cursor()
     
                try:
                    sql = "select * from users where id = %s"
                    val = (id,)
                    mycursor.execute(sql, val)
                    users = mycursor.fetchone()
                    ematricule.delete(0, END)
                    enom.delete(0, END)
                    eprenom.delete(0, END)
     
                    enom.focus_set()
                    ematricule.insert(0, str(users[0]))
                    enom.insert(0, str(users[1]))
                    eprenom.insert(0, str(users[2]))
     
                except Exception as e:
                    print(e)
                    mysqldb.rollback()
                    mysqldb.close()
     
            global ematricule
            global enom
            global eprenom
     
            # creer frame pour identifiant
            frame_ident = Frame(self, bg="#F5CBA7", bd=1, relief=SUNKEN)
            frame_ident.pack(fill=X)
     
            # titre Frame titre Identifiant
            label_title = tk.Label(frame_ident, text="identifiants patient", font=("Courrier", 15), bg="#F5CBA7",
                                   fg="black")
            label_title.grid(row=1, column=0)
     
            lmatricule = tk.Label(frame_ident, text="matricule", bg="#F5CBA7").grid(row=2, column=0)
            ematricule = tk.Entry(frame_ident)
            ematricule.grid(row=2, column=1)
            lnom = Label(frame_ident, text="nom", bg="#F5CBA7").grid(row=3, column=0)
            enom = tk.Entry(frame_ident)
            enom.grid(row=3, column=1)
            lprenom = tk.Label(frame_ident, text="prenom", bg="#F5CBA7").grid(row=3, column=2)
            eprenom = tk.Entry(frame_ident)
            eprenom.grid(row=3, column=3)
     
     
            lookDB()
    merci de m'avoir lu

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

    Dans la définition de la classe PageTwo, searchDB est une fonction imbriquée dans la méthode __init__ (qui ne prend pas de paramètre...).
    Essayez d'ouvrir un tuto. et d'apprendre les bases de la POO avec Python, car ce n'est pas si difficile et ça mérite d'y passer un peu de temps.

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

  3. #3
    Membre actif
    Homme Profil pro
    Architecte matériel
    Inscrit en
    Juin 2014
    Messages
    18
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 35
    Localisation : Tunisie

    Informations professionnelles :
    Activité : Architecte matériel
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Juin 2014
    Messages : 18
    Par défaut
    super, je vais faire ça et je vous tien au courant . merci beaucoup

  4. #4
    Membre actif
    Homme Profil pro
    Architecte matériel
    Inscrit en
    Juin 2014
    Messages
    18
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 35
    Localisation : Tunisie

    Informations professionnelles :
    Activité : Architecte matériel
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Juin 2014
    Messages : 18
    Par défaut
    rien n'y fait. j'ai compris comment importer une fonction mais pas une variable..

  5. #5
    Expert éminent
    Homme Profil pro
    Architecte technique retraité
    Inscrit en
    Juin 2008
    Messages
    21 715
    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 715
    Par défaut
    Citation Envoyé par kanon22 Voir le message
    rien n'y fait. j'ai compris comment importer une fonction mais pas une variable..
    Si vous avez bossé à peine 2 heures sur la POO avec Python... c'est même pas la peine d'essayer quoi que ce soit.

    Par construction une "variable" est spécifique à un module/script: on n'importe pas une variable!

    Lorsqu'on écrit "import creerDossier" ça importe le module correspondant et ça assigne l'objet module à la variable creerDossier. Si on avait écrit "import creerDossier as toto" la variable assignée à l'objet module sera toto.

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

  6. #6
    Membre actif
    Homme Profil pro
    Architecte matériel
    Inscrit en
    Juin 2014
    Messages
    18
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 35
    Localisation : Tunisie

    Informations professionnelles :
    Activité : Architecte matériel
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Juin 2014
    Messages : 18
    Par défaut
    wé, j'étais bien arrivé à cette conclusion. je suis désolé , je suis vraiment débutant. en fait je suis médecin et je participe un CEC intelligence artificielle de la santé. on vient tout juste de commencer. mais sinon, pas de base en info :/
    Donc la solution pour récupérer l'ID, serait d'enregistrer la variable?

  7. #7
    Expert éminent
    Homme Profil pro
    Architecte technique retraité
    Inscrit en
    Juin 2008
    Messages
    21 715
    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 715
    Par défaut
    Vous êtes parti à vouloir réaliser un petit projet qu'on fait après son apprentissage pour montrer qu'on est capable de faire quelque chose avec ce qu'on a appris.

    Problème, vous n'avez pas pris le temps d'apprendre!
    Simplifiez!
    • Si vous ne maîtrisez pas les modules, Python ne vous oblige pas à les utiliser: tout dans le même script, dans un premier temps, fonctionne.
    • Si vous ne pigez rien à la POO, tkinter ne vous impose pas de l'utiliser pour écrire une application,...


    Et si simplifier ne vous avance pas, ouvrez un tuto. passez y du temps avant de vouloir faire des choses trop compliquées: on ne peut pas vous expliquer ce que vous n'avez pas essayé de comprendre. On pourrait juste coder à votre place... mais on ne fait pas dans le dépannage express des gens pressés de coder qui ont zappé la case "apprendre".

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

  8. #8
    Membre actif
    Homme Profil pro
    Architecte matériel
    Inscrit en
    Juin 2014
    Messages
    18
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 35
    Localisation : Tunisie

    Informations professionnelles :
    Activité : Architecte matériel
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Juin 2014
    Messages : 18
    Par défaut
    a vrai dire, je suis en cours de formation. Et à la fin de la formation, on aura un petit projet à faire et des professionnels vont nous assister. J'ai certes un peu accélérer les choses vu mon niveau, mais voilà, ce petit projet me tenait à cœur. Et de toute façon, j'ai participer à ce CEC avec cette idée en tête. c'est pas grave, je finirai pas trouver (comme toujours)

  9. #9
    Membre éclairé

    Inscrit en
    Novembre 2008
    Messages
    423
    Détails du profil
    Informations forums :
    Inscription : Novembre 2008
    Messages : 423
    Par défaut
    Citation Envoyé par kanon22 Voir le message
    a vrai dire, je suis en cours de formation. Et à la fin de la formation, on aura un petit projet à faire et des professionnels vont nous assister. J'ai certes un peu accélérer les choses vu mon niveau, mais voilà, ce petit projet me tenait à cœur. Et de toute façon, j'ai participer à ce CEC avec cette idée en tête. c'est pas grave, je finirai pas trouver (comme toujours)
    Bonjour,
    Je n'ai pas beaucoup approfondi mais je pense que votre code souffre d'un problème d'indentation.
    Ce que vous écrivez est possible (le langage l'autorise)
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
     
    ...
        def ...
            def ...
            def...
    Mais je pense que vous voulez écrire
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
     
    ...
        def ...
        def ...
        def...
    En python, l'indentation compte :-)

    Par ailleurs, les méthodes n'ont pas le paramètre qui référence l'objet auquel est rattaché la méthode (self, en général), ce qui va poser un problème...

  10. #10
    Membre actif
    Homme Profil pro
    Architecte matériel
    Inscrit en
    Juin 2014
    Messages
    18
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 35
    Localisation : Tunisie

    Informations professionnelles :
    Activité : Architecte matériel
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Juin 2014
    Messages : 18
    Par défaut
    je crois que dans mon script, il est nécessaire d'écrire le code de la sorte.
    Pour appeler l'ID, la meilleure façon que j'ai trouvé est de le sauvegarder sur un fichier, comme tel :

    script 3
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
     
     def searchDB():
                id = ematricule.get()
                with open("idsaver.txt","w") as fic:
                    last_id = id
                    fic.write(str(last_id))
    script 4
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
     
            def lookDB():
                with open("idsaver.txt", "r") as fic:
                    content = fic.read()
                    print(content)
    le problème est que avec Python, il lit la variable à l'ouverture du programme. J'ai pas trouvé le moyen de faire un Update.
    par exp, sur C#, il y a un e fonction Start() qui se lit au début et une fonction Update() qui se relit toutes les frames.
    J'ai essayé de créer une boucle ou autre, mais ça ne fait que bloquer le programme. :/

  11. #11
    Membre prolifique
    Avatar de Sve@r
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Février 2006
    Messages
    12 827
    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 827
    Billets dans le blog
    1
    Par défaut
    Bonjour
    Citation Envoyé par kanon22 Voir le message
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
     
     def searchDB():
                id = ematricule.get()
                with open("idsaver.txt","w") as fic:
                    last_id = id
                    fic.write(str(last_id))
    Quand tu vas acheter du pain, est-ce que tu commences par sortir les pièces de ton porte monnaie pour les ranger dans la poche gauche, puis ensuite les sortir de la gauche pour les mettre dans la droite pour enfin les ressortir de la droite pour payer?
    Pourquoi alors transférer ematricule.get() dans "id" pour transférer ensuite "id" dans "last_id" avant d'enregistrer ce "last_id" ??????????
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    def searchDB():
    	with open("idsaver.txt","w") as fic:
    		fic.write(str(ematricule.get()))
    Citation Envoyé par kanon22 Voir le message
    Pour appeler l'ID, la meilleure façon que j'ai trouvé est de le sauvegarder sur un fichier, comme tel
    Il n'y a pas de "meilleure" façon, seulement des façons adaptées à tes besoins. Passer par un fichier c'est utile si tu veux garder l'information après la fin du programme pour pouvoir la récupérer quand tu le relances. Si c'est juste pour transmettre une information entre deux instants du même fonctionnement du programme c'est alors la pire des méthodes.

    Citation Envoyé par kanon22 Voir le message
    le problème est que avec Python, il lit la variable à l'ouverture du programme. J'ai pas trouvé le moyen de faire un Update.
    par exp, sur C#, il y a un e fonction Start() qui se lit au début et une fonction Update() qui se relit toutes les frames.
    J'ai essayé de créer une boucle ou autre, mais ça ne fait que bloquer le programme. :/
    Je connais pas bien Tk mais Qt (que j'utilise) possède un objet QSplashScreen() qui s'exécute quand on affiche le frame principal (semblable au Start() que tu cites) et un objet QTimer() qui peut exécuter des actions toutes les "x" unités de temps. A voir si Tk n'aurait pas un équivalent. Sinon la seule solution sera de passer par des processus en parallèles (le premier qui gère ton appli et le second qui gère l'update) mais c'est de la programmation assez avancée.
    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]

  12. #12
    Membre actif
    Homme Profil pro
    Architecte matériel
    Inscrit en
    Juin 2014
    Messages
    18
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 35
    Localisation : Tunisie

    Informations professionnelles :
    Activité : Architecte matériel
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Juin 2014
    Messages : 18
    Par défaut
    Citation Envoyé par Sve@r Voir le message
    Bonjour

    Quand tu vas acheter du pain, est-ce que tu commences par sortir les pièces de ton porte monnaie pour les ranger dans la poche gauche, puis ensuite les sortir de la gauche pour les mettre dans la droite pour enfin les ressortir de la droite pour payer?
    Pourquoi alors transférer ematricule.get() dans "id" pour transférer ensuite "id" dans "last_id" avant d'enregistrer ce "last_id" ??????????
    si j'ai fait ça, c'est parce que j'ai eu du mal à aller chercher la valeur ID de la fonction searchDB() de la fonction __init__ de la classe PageTwo du script "créer dossier".
    j'ai un peu bidouillé pour pouvoir le faire, en sortant la fonction searchDB() de la classé PageTwo. Toutefois, reste le problème de l'update.

    En fait ce qui se passe, c'est que j'ouvre mon programme, je clique sur "rechercher" et l'ID s'enregistre bien, sauf que quand je clique sur "Dossier Patient", il m'ouvre le dossier de l'ID enregistré à la session précédente vu qu'il le lit à l'ouverture du programme et ne le relit plus ce qui est bien embêtant.

    Pour être sûr de ce raisonnement, j'ai rajouter un bouton sur le script "dossierPatient" qui appelle la fonction "lookDB()", et ça fonctionne et ça met bien a jour les données du patient avec le nouvel ID, mais je trouve ça contraignant.

    Ce qui serait l'idéal, c'est de pouvoir rappeler la fonction lookDB() de la classe PageThree() l'orsque je détermine l'ID c'est à dire dans un autre script, mais j'ai du mal appeler une fonction qui se trouve dans __init__(). :/

    Je vous avoue, que je ne conçois pas qu'une fonctionnalité aussi primordiale nécessite 2 jours de recherche et 50 onglets ouverts... et ce sans solution.

  13. #13
    Membre prolifique
    Avatar de Sve@r
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Février 2006
    Messages
    12 827
    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 827
    Billets dans le blog
    1
    Par défaut
    Citation Envoyé par kanon22 Voir le message
    Ce qui serait l'idéal, c'est de pouvoir rappeler la fonction lookDB() de la classe PageThree() l'orsque je détermine l'ID c'est à dire dans un autre script, mais j'ai du mal appeler une fonction qui se trouve dans __init__(). :/
    On ne peut pas appeler manuellement __init__(). Le __init__() est une fonction qui sert à initialiser les choses quand on instancie (crée) un objet.
    Maintenant rien ne t'interdit de définir une méthode truc() qui sera appelée depuis __init__() et que tu peux ensuite appeler manuellement quand tu veux
    Code python : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    class toto:
    	def __init__(self):
    		...
    		self.truc()
    	# __init__()
     
    	def truc(self):
    		...
    	# truc()
    # class toto
     
    xxx=toto()
    xxx.truc()

    Citation Envoyé par kanon22 Voir le message
    Je vous avoue, que je ne conçois pas qu'une fonctionnalité aussi primordiale nécessite 2 jours de recherche et 50 onglets ouverts... et ce sans solution.
    Python (comme tous les autres langages) possède des outils "élémentaires". Comme les légos qui ne sont que des carrés et des cubes. C'est à toi d'associer les différents outils offerts pour créer tes fonctionnalités qui sont peut-être "primordiales" pour toi mais pas pour la majorité. Peut-être qu'un autre sera content lui que la mise à jour soit manuelle (obligé de cliquer sur le bouton "dossierPatient") et non pas automatique au risque alors à se faire quand il ne le veut pas. Quand tu fermes un document Word, tu as 3 boutons qui t'offrent 3 possibilités "enregister", "annuler" ou "quitter". Ca te plairait que l'enregistrement se fasse automatiquement au risque de te pourrir un document modifié par erreur????
    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]

  14. #14
    Membre actif
    Homme Profil pro
    Architecte matériel
    Inscrit en
    Juin 2014
    Messages
    18
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 35
    Localisation : Tunisie

    Informations professionnelles :
    Activité : Architecte matériel
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Juin 2014
    Messages : 18
    Par défaut
    je vois exactement ce que tu veux dire.

    Avec les éléments que j'ai en main et mes faibles connaissances, (oui, parce que, ne pas savoir faire un truc, ne m'a jamais empêcher d'essayer :p), est que au lieu de switcher les frames en arrivant, dans dossierPatient, est de lancer une nouvelle fenêtre, ce qui va empêcher que l'ID ne se lise dés le début, mais seulement après l'avoir déterminer et puis, ça me permettra dans lancer plusieurs dossier en même temps.

    Je vous remercie tous d'avoir pris le temps de me répondre. J'ai beaucoup appris face à cette problématique en explorant chacune de vos remarques.

  15. #15
    Membre éclairé

    Inscrit en
    Novembre 2008
    Messages
    423
    Détails du profil
    Informations forums :
    Inscription : Novembre 2008
    Messages : 423
    Par défaut
    Citation Envoyé par kanon22 Voir le message
    je crois que dans mon script, il est nécessaire d'écrire le code de la sorte.
    OK. Ca me semble néanmoins assez compliqué. Après plusieurs années à utiliser python, je n'ai eu que très rarement besoin de faire appel à de telles façons de faire.

Discussions similaires

  1. Réponses: 2
    Dernier message: 07/06/2013, 08h24
  2. [XL-2007] récupérer une variable d'un autre module
    Par dodo69 dans le forum Macros et VBA Excel
    Réponses: 10
    Dernier message: 08/02/2011, 08h38
  3. récupérer une variable dans un autre swf
    Par sonico dans le forum Flash
    Réponses: 0
    Dernier message: 04/11/2009, 11h25
  4. Récupérer une valeur via un autre script
    Par Olivier Regnier dans le forum Langage
    Réponses: 2
    Dernier message: 14/11/2007, 10h12
  5. Passer une variable Javascript à un autre script
    Par Niouts dans le forum Général JavaScript
    Réponses: 10
    Dernier message: 30/08/2006, 08h48

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