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

Windows Forms Discussion :

[VB.Net] probleme de lecture de fichier


Sujet :

Windows Forms

  1. #1
    Membre habitué
    Homme Profil pro
    retraité
    Inscrit en
    Mars 2003
    Messages
    397
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Saône et Loire (Bourgogne)

    Informations professionnelles :
    Activité : retraité

    Informations forums :
    Inscription : Mars 2003
    Messages : 397
    Points : 165
    Points
    165
    Par défaut [VB.Net] probleme de lecture de fichier
    bonjour,

    dans le code suivant la première boucle while fonctionne alors que la seconde ne "tourne pas" ?
    si quelq'un peut m'expliquer. Merci d'avance

    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
        Private Sub BTcateg_Click_1(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles BTcateg.Click
            Dim i As Integer = 0
            Dim j As Integer = 0
            Dim mot As String
            Dim cod() As String = {"pa", "BF", "po", "ta", "ser"}
            Dim fl As Integer = 0
            FileClose()
            FileOpen(100, My.Application.Info.DirectoryPath + "\element", OpenMode.Random, , , Len(enreg))
     
            mot = TXTcateg.Text
            If mot = "cour" Then GoTo suite
     
            suivi.Maximum = 6000
            While Not EOF(100)
                i = i + 1
                FileGet(100, enreg)
                suivi.Value = i
                If Trim(enreg.num).Contains(mot) = True Then
     
                    j = j + 1
                    tab(j, 1) = Trim(enreg.num)
     
                End If
            End While
            GoTo fin
    suite:
            i = 0
     
            suivi.Maximum = 6000
            While Not EOF(100)
                i = i + 1 : fl = 0
                FileGet(100, enreg)
                suivi.Value = i
                    If Trim(enreg.num).Contains("pa") Then fl = 1
                If fl = 0 Then
                    j = j + 1
                    'tab(j, 1) = Trim(enreg.num)
     
     
                End If
     
            End While
            FileClose()
    fin:
     
     
        End Sub

  2. #2
    jab
    jab est déconnecté
    Rédacteur
    Avatar de jab
    Homme Profil pro
    SharePoint developpeur
    Inscrit en
    Février 2004
    Messages
    1 173
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 60
    Localisation : Belgique

    Informations professionnelles :
    Activité : SharePoint developpeur
    Secteur : Service public

    Informations forums :
    Inscription : Février 2004
    Messages : 1 173
    Points : 4 339
    Points
    4 339
    Par défaut
    Aie ça c'est du VB à l'ancienne

    commence déjà par enlever ces goto que je ne saurai voir. Ensuite ferme ton fichier à la fin et non seulement dans la deuxième opération. Ainsi tu n'aura plus à le fermer au début.

    Ensuit pourquoi
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
     
        If Trim(enreg.num).Contains("pa") Then fl = 1
                If fl = 0 Then
                    j = j + 1
                    'tab(j, 1) = Trim(enreg.num)
                End If
    alors que fl est remis à 0 à chaque passage.

    Fait
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
     
        If Not Trim(enreg.num).Contains("pa") 
               j = j + 1
               'tab(j, 1) = Trim(enreg.num)
        End If
    Et pourquoi un Trim d'ailleur.

    Après on y verra déjà plus clair.

  3. #3
    jab
    jab est déconnecté
    Rédacteur
    Avatar de jab
    Homme Profil pro
    SharePoint developpeur
    Inscrit en
    Février 2004
    Messages
    1 173
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 60
    Localisation : Belgique

    Informations professionnelles :
    Activité : SharePoint developpeur
    Secteur : Service public

    Informations forums :
    Inscription : Février 2004
    Messages : 1 173
    Points : 4 339
    Points
    4 339
    Par défaut
    Tant qu'on y est évite
    Met le sur deux lignes c'est bien plus lisible

  4. #4
    Membre habitué
    Homme Profil pro
    retraité
    Inscrit en
    Mars 2003
    Messages
    397
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Saône et Loire (Bourgogne)

    Informations professionnelles :
    Activité : retraité

    Informations forums :
    Inscription : Mars 2003
    Messages : 397
    Points : 165
    Points
    165
    Par défaut
    ok j'ai viré les goto.
    Comme je ne voulais pas encombrer le post j'ai volontaire tronqué la procédure je vous la livre en complet. les trim sont là pour virer les espace qui sont dans le fichier "element" qui est un fichier récupéré et pas très propre

    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
        Private Sub BTcateg_Click_1(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles BTcateg.Click
            Dim i As Integer = 0
            Dim j As Integer = 0
            Dim mot As String
            Dim cod() As String = {"pa", "BF", "po", "ta", "ser"}
            Dim fl As Integer = 0
            FileClose()
            FileOpen(100, My.Application.Info.DirectoryPath + "\element", OpenMode.Random, , , Len(enreg))
            suivi.Maximum = 6000
            mot = TXTcateg.Text
            If mot <> "cour" Then
     
    'première boucle 
                While Not EOF(100)
                    i = i + 1
                    FileGet(100, enreg)
                    suivi.Value = i
                    If Trim(enreg.num).Contains(mot) = True Then
     
                        j = j + 1
                        tab(j, 1) = Trim(enreg.num)
                        tab(j, 2) = Trim(enreg.desi)
                        tab(j, 3) = Trim(enreg.grav)
                        tab(j, 4) = Trim(enreg.qtemis)
                        tab(j, 5) = Trim(enreg.annee)
                        tab(j, 6) = Trim(enreg.typ)
                        tab(j, 7) = Trim(enreg.couleur)
                        tab(j, 8) = Trim(enreg.dent)
                        tab(j, 9) = Trim(enreg.valfac)
                        tab(j, 10) = Trim(enreg.info)
                        tab(j, 11) = Trim(enreg.photo)
                        tab(j, 12) = Trim(enreg.att2)
                        tab(j, 13) = Trim(enreg.cotneuf)
                        tab(j, 14) = Trim(enreg.cotneufchar)
                        tab(j, 15) = Trim(enreg.cotoblit)
                        tab(j, 16) = Trim(enreg.dessin)
                        tab(j, 13) = tab(j, 13).Replace(".", ",")
                        tab(j, 14) = tab(j, 14).Replace(".", ",")
                        tab(j, 15) = tab(j, 15).Replace(".", ",")
                    End If
                End While
            End If
     
    'seconde boucle
            Label8.Text = j
            i = 0
            While Not EOF(100)
                i = i + 1
                fl = 0
                FileGet(100, enreg)
                suivi.Value = i
                For i = 0 To 4
                    If Trim(enreg.num).Contains(cod(i)) Then fl = 1
                Next
                If fl = 0 Then
                    j = j + 1
                    tab(j, 1) = Trim(enreg.num)
                    tab(j, 2) = Trim(enreg.desi)
                    tab(j, 3) = Trim(enreg.grav)
                    tab(j, 4) = Trim(enreg.qtemis)
                    tab(j, 5) = Trim(enreg.annee)
                    tab(j, 6) = Trim(enreg.typ)
                    tab(j, 7) = Trim(enreg.couleur)
                    tab(j, 8) = Trim(enreg.dent)
                    tab(j, 9) = Trim(enreg.valfac)
                    tab(j, 10) = Trim(enreg.info)
                    tab(j, 11) = Trim(enreg.photo)
                    tab(j, 12) = Trim(enreg.att2)
                    tab(j, 13) = Trim(enreg.cotneuf)
                    tab(j, 14) = Trim(enreg.cotneufchar)
                    tab(j, 15) = Trim(enreg.cotoblit)
                    tab(j, 16) = Trim(enreg.dessin)
                    tab(j, 13) = tab(j, 13).Replace(".", ",")
                    tab(j, 14) = tab(j, 14).Replace(".", ",")
                    tab(j, 15) = tab(j, 15).Replace(".", ",")
     
                End If
                Label8.Text = j
                lig = j
            End While
            FileClose()
     
     
     
        End Sub

  5. #5
    jab
    jab est déconnecté
    Rédacteur
    Avatar de jab
    Homme Profil pro
    SharePoint developpeur
    Inscrit en
    Février 2004
    Messages
    1 173
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 60
    Localisation : Belgique

    Informations professionnelles :
    Activité : SharePoint developpeur
    Secteur : Service public

    Informations forums :
    Inscription : Février 2004
    Messages : 1 173
    Points : 4 339
    Points
    4 339
    Par défaut
    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
     
    Private Sub BTcateg_Click_1(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles BTcateg.Click
    ...
            If mot <> "cour" Then
     
                'première boucle 
                While Not EOF(100)
                     ...
                End While
     
            Else
     
                'seconde boucle
                Label8.Text = j
                i = 0
                While Not EOF(100)
                    ...
                End While
            end if
            FileClose()
     
        End Sub

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

Discussions similaires

  1. Probleme de lecture de fichier swf avec c#
    Par Vince57 dans le forum Windows Forms
    Réponses: 4
    Dernier message: 14/06/2006, 14h18
  2. Probleme de lecture de fichier
    Par calimero642 dans le forum Langage
    Réponses: 1
    Dernier message: 19/05/2006, 12h20
  3. Probleme de lecture de fichier
    Par ArkAng3 dans le forum MFC
    Réponses: 9
    Dernier message: 11/12/2005, 20h47
  4. Réponses: 19
    Dernier message: 31/10/2005, 15h04
  5. [vb.net][xml] probleme de lecture de fichier
    Par graphicsxp dans le forum Windows Forms
    Réponses: 4
    Dernier message: 27/07/2005, 11h51

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