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 :

Acces en Base avec problème d'insertion


Sujet :

Python

  1. #21
    Membre éclairé Avatar de dedalios
    Homme Profil pro
    concepteur d'application
    Inscrit en
    Février 2008
    Messages
    495
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Indre et Loire (Centre)

    Informations professionnelles :
    Activité : concepteur d'application
    Secteur : Santé

    Informations forums :
    Inscription : Février 2008
    Messages : 495
    Par défaut probleme
    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
     
     
    lecture  du fichier x...
     
    ...
        global fichier_Valo_limite 
        global fichier_Valo_limite_entete 
        global fichier_0150_indx
        global fichier_0150_SQL
        global la_valo_limite
     
    ...
         if(valeur=='0150') :     
                la_valo_limite= Ext_VALOS_LIMITE(ligne)            # 0150    Valorisation de la limite   ..
      # ligne contient des donnes du fichier lu par le process global
      # valeur une donnée précédemment extraite de ligne dans le traitement sa valeur est '0150'
    ...
                print(la_valo_limite.__csv_donnee__())
     
                fichier_150_SQL.append(la_valo_limite.__csv_donnee__())   
     
     
                #------------------------------------- 
                if(fichier_150_indx == 250):
                    la_valo_limite.db_insertion_v2(projet,fichier_150_SQL)
                    fichier_150_indx =1
                    fichier_150_SQL=[]
                #---------------------------------
    ...

    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
    class Valo_limite(object):
     
        def __init__(self,Type_enr,  Drapeau, Code_Produit): 
        # vérification
            if(Type_enr != '0150'):
                print("Erreur de type d'enregitement Valo_limite: %s" % Type_enr)
                exit(1)
            if(Drapeau not in type_Drapeau) :
                print("Type de Drapeau incohérent Valo_limite: %s" % Drapeau)
                exit(1)
            self.Type_enr = Type_enr
            self.Drapeau = Drapeau
            self.Code_Produit = Code_Produit
     
        def __csv_donnee__(self):
            resulta = [self.Type_enr,self.Drapeau,self.Code_Produit]
            return resulta 
        pass
     
     
        def db_insertion_v2(self,nombase,donnee):
            rq = """ INSERT INTO Valo_limite_150
            (Type_enr, Drapeau, Code_Produit)  
             VALUES(?, ?, ?) """
            nombase =sqlite3.connect(nombase.dbNAME)  # ouverture DB
            curseur = nombase.cursor() # appel au curseur
            curseur.executemany(rq,donnee)
            nombase.commit()
            nombase.close()      
     
    pass

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    def Ext_VALOS_LIMITE(lnsrc):
        Type_enr = lnsrc[0:4] # O150
        Drapeau = lnsrc[4:5] # O
        Code_Produit = lnsrc[5:15] # O
        la_vlm = Valo_limite(Type_enr,  Drapeau, Code_Produit)
        return la_vlm


    mon problème est le problème de la variable fichier_150_SQL:

    cette variable est définie en début deprogramme
    fichier_150_SQL=[]

    problème ce bug
    fichier_150_SQL.append(la_valo_limite.__csv_donnee__())
    UnboundLocalError: local variable 'fichier_150_SQL' referenced before assignment
    Autre point la commande print " print(la_valo_limite.__csv_donnee__()) " qui ne fait rien.....

    si je met en commentaire la commande erronée
    if(fichier_150_indx == 250):
    UnboundLocalError: local variable 'fichier_150_indx' referenced before assignment

  2. #22
    Expert éminent
    Homme Profil pro
    Architecte technique retraité
    Inscrit en
    Juin 2008
    Messages
    21 790
    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 790
    Par défaut
    Quand je lis global fichier_0150_SQL et UnboundLocalError: local variable 'fichier_150_indx' referenced before assignment, je me dis que vous n'arrivez plus à relire le code que vous avez écrit.
    Parfois, c'est une question de fatigue: dormir un peu, s'aérer la tête,...

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

  3. #23
    Membre éclairé Avatar de dedalios
    Homme Profil pro
    concepteur d'application
    Inscrit en
    Février 2008
    Messages
    495
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Indre et Loire (Centre)

    Informations professionnelles :
    Activité : concepteur d'application
    Secteur : Santé

    Informations forums :
    Inscription : Février 2008
    Messages : 495
    Par défaut UnboundLocalError: local variable 'fichier_150_SQL' referenced before assignment
    Dans un sens peut-être
    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
    class Valo_limite(object):
     
        def __init__(self,Type_enr, Valeur):
        # vérification
     
            self.Type_enr = Type_enr
            self.Valeur = Valeur
            pass
     def __csv_donnee__(self):
            resulta = [self.Type_enr, self.Valeur]
            return resulta 
        pass
     
     
        def __csv_entete__(self):
            resulta =  ["Type_enr",   "Valeur"]
            return resulta 
        pass
        def csv_donnee(self, nomfichier):
            """  Ecriture du fichier format csv -donnee"""
            ecrire_csv = csv.writer(nomfichier, delimiter = ';') # Codage du fichier csv délimiter de champ
            ecrire_csv.writerow(self.__csv_donnee__())  # donnée  
     
        def csv_entete(self,nomfichier):
            """  Ecriture du fichier format csv -entete"""
            ecrire_csv = csv.writer(nomfichier, delimiter = ';') # Codage du fichier csv délimiter de champ
            ecrire_csv.writerow(self.__csv_entete__())  # donnée 
     
     
        def db_insertion(self,nombase):
            rq = """ INSERT INTO v0
            (Type_enr,  Valeur) 
             VALUES(?,  ?) """
     
            nombase =sqlite3.connect(nombase.dbNAME)  # ouverture DB
            curseur = nombase.cursor() # appel au curseur
            curseur.execute(rq,self.__csv_donnee__())
            nombase.commit()
            nombase.close()     
     
     
        def db_insertion_v2(self,nombase,donnee):
            rq = """ INSERT INTO V0
            (Type_enr, Valeur) 
             VALUES(?,  ?) """
            nombase =sqlite3.connect(nombase.dbNAME)  # ouverture DB
            curseur = nombase.cursor() # appel au curseur
            curseur.executemany(rq,donnee)
            nombase.commit()
            nombase.close()


    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
     
    ...
    from  Explorateur import *
    from  Class_Tribox_new import *   
     
    ...
    def Ext_VALOS_LIMITE(lnsrc):
        Type_enr = lnsrc[0:4] # O150
        Valeur = converti_montant(lnsrc[41:59],14,2)
        la_vlm = Valo_limite(Type_enr,  Nb_de_Mois, Valeur)
        return la_vlm
     
     
    def Extraire_type(src):
        global file_gt
        for ligne in src:
     
            if(ligne[0:4] == "0000"):
               print("coucou")
    ...
            elif(ligne[0:4] == "0150"):                                                   
                la_valo_limite= Ext_VALOS_LIMITE(ligne)            # 0150    Valorisation de la limite   
                if(fichier_Valo_limite_entete ==  False):
                    la_valo_limite.csv_entete(fichier_Valo_limite)
                    fichier_Valo_limite_entete= True
     
                fichier_150_indx =1
                fichier_150_SQL=[]
                la_valo_limite.csv_donnee(fichier_Valo_limite)  
     
                fichier_150_SQL.append(la_valo_limite.__csv_donnee__())                            
                #------------------------------------- 
                if(fichier_150_indx == 250):
                    la_valo_limite.db_insertion_v2(projet,fichier_150_SQL)
                    fichier_150_indx =1
                    fichier_150_SQL=[]
                #---------------------------------
     
    # Base Application
        if __name__ == '__main__':
     
    # Variable 
    ...
             fichier_150_SQL=[]
    ...
     
              Extraire_type(fichier) # traitement de donner du fichier d'entree
     
       # fin de boucle charger 150
              la_valo_limite.db_insertion_v2(projet,fichier_150_SQL)

+ Répondre à la discussion
Cette discussion est résolue.
Page 2 sur 2 PremièrePremière 12

Discussions similaires

  1. Réponses: 4
    Dernier message: 09/03/2015, 16h30
  2. Réponses: 11
    Dernier message: 21/05/2012, 12h42
  3. [MySQL] problème d'insertion de données à une base avec le php
    Par bibaa dans le forum PHP & Base de données
    Réponses: 0
    Dernier message: 19/08/2010, 01h11
  4. Accès à la base avec le N° personnel
    Par maxeur dans le forum Sécurité
    Réponses: 8
    Dernier message: 17/02/2007, 00h37

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