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

VB 6 et antérieur Discussion :

ouvrir et enregistrer un MsFlexgrid


Sujet :

VB 6 et antérieur

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre éclairé
    Homme Profil pro
    Enseignant
    Inscrit en
    Juin 2012
    Messages
    317
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Enseignant
    Secteur : Enseignement

    Informations forums :
    Inscription : Juin 2012
    Messages : 317
    Par défaut ouvrir et enregistrer un MsFlexgrid
    Bonjour à tous,

    J'ai un MSFlexgrid que j'enregistre en format text avec ce 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
    19
    20
    21
    22
    23
    24
    25
    26
    27
    Private Sub enregistrer_Click()
     
    Dim colonne As Integer
    Dim Ligne As Integer
    Dim cptligne As Integer
    Dim cptcolonne As Integer
    Dim chaine As String
    Dim emp
     
     
    emp = App.Path
     
    Open emp + "nomfichier.txt" For Output As #1
    colonne = Me.MSFlexGrid1.Cols
    Ligne = Me.MSFlexGrid1.Rows
    For cptligne = 0 To Ligne - 1
    For cptcolonne = 0 To colonne - 1
    chaine = chaine & Me.MSFlexGrid1.TextMatrix(cptligne, cptcolonne)
    chaine = chaine & "|"
    Next cptcolonne
    Print #1, chaine
    chaine = ""
    Next cptligne
     
    Close #1
     
    End Sub
    Le résultat n'est pas au top^car il y a plein de traits verticaux sur la feuille mais les données sont bien enregistrées. Le gros problème est de pouvoir ouvrir les fichiers enregistrés au format text.
    J'ai bricoler un bout de code qui utilise la boite de dialogue ouvrir mais je n'arrive pas à lire et encore moins à écrire le contenu du fichier dans mon MSFlexgrid ( j'utilise le même MSFexgrid qui à créer le fichier pour le r'ouvrir)

    voici le code qui ne fonctionne pas :

    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
     
    Private Sub ouvrir_Click()
     
    Dim ff As Integer
    Dim i As Integer
    Dim j As Integer
    Dim A$
    Dim MonFichier
     
    i = MSFlexGrid1.Rows
     
     
    ff = FreeFile
    CommonDialog1.ShowOpen
    MonFichier = CommonDialog1.FileName
    Open MonFichier For Input As #ff
     
    Do While Not EOF(ff)
        MSFlexGrid1.Rows = i + 1
        For j = 0 To 104
            If Not EOF(ff) Then
                Input #ff, A$
                MSFlexGrid1.TextMatrix(i, j) = A$
            Else
                Exit Do
            End If
        Next j
        i = i + 1
    Loop
     
    Close #ff
    End Sub
    il doit me manquer un petit quelque chose que mes maigre connaissances ne me permettent pas de trouver

    merci pour votre aide toujours précieuse

    cordialement

    Didier

  2. #2
    Membre émérite Avatar de DAUDET78
    Homme Profil pro
    retraité
    Inscrit en
    Janvier 2008
    Messages
    635
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 82
    Localisation : France, Yvelines (Île de France)

    Informations professionnelles :
    Activité : retraité
    Secteur : Industrie

    Informations forums :
    Inscription : Janvier 2008
    Messages : 635
    Par défaut
    Citation Envoyé par dmoluc Voir le message
    Le résultat n'est pas au top^car il y a plein de traits verticaux sur la feuille
    Ca me semble normal .... c'est toi qui les ajoute

  3. #3
    Membre éclairé
    Homme Profil pro
    Enseignant
    Inscrit en
    Juin 2012
    Messages
    317
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Enseignant
    Secteur : Enseignement

    Informations forums :
    Inscription : Juin 2012
    Messages : 317
    Par défaut
    merci c'est déjà ça : à force de piquer des codes à droites à gauche sans les comprendres totalement, je fais des bétises

  4. #4
    Membre éclairé
    Homme Profil pro
    Enseignant
    Inscrit en
    Juin 2012
    Messages
    317
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Enseignant
    Secteur : Enseignement

    Informations forums :
    Inscription : Juin 2012
    Messages : 317
    Par défaut
    j'ai essayé de faire l'inverse de l'enregistrement en utilisant input, mais je n'arrive toujours pas à ouvrir le fichier

    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
     
     
    Private Sub ouvrir_Click()
     
    Dim MonFichier
    Dim colonne As Integer
    Dim ligne As Integer
    Dim cptligne As Integer
    Dim cptcolonne As Integer
    Dim chaine As String
    Dim emp
     
     
    CommonDialog1.ShowOpen
     
    MonFichier.Text = CommonDialog1.FileName
     
    Open "MonFichier" For Input As #1
    colonne = Me.MSFlexGrid1.Cols
    ligne = Me.MSFlexGrid1.Rows
    For cptligne = 0 To ligne - 1
    For cptcolonne = 0 To colonne - 1
    chaine = chaine & Me.MSFlexGrid1.TextMatrix(cptligne, cptcolonne)
    chaine = chaine & " "
    Next cptcolonne
    Print #1, chaine
    chaine = ""
    Next cptligne
     
    Close #1
     
    End Sub
    "CommonDialog1.FileName" contient bien le fichier mais impossible de l'ouvrir, cette ligne de code ne fonctionne pas :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
     Open "MonFichier" For Input As #1
    quelqu'un aurait une idée, ce serait sympat, merci

  5. #5
    Membre émérite Avatar de DAUDET78
    Homme Profil pro
    retraité
    Inscrit en
    Janvier 2008
    Messages
    635
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 82
    Localisation : France, Yvelines (Île de France)

    Informations professionnelles :
    Activité : retraité
    Secteur : Industrie

    Informations forums :
    Inscription : Janvier 2008
    Messages : 635
    Par défaut
    Peut être
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Open MonFichier.text For Input As #1

  6. #6
    Expert confirmé
    Avatar de ProgElecT
    Homme Profil pro
    Retraité
    Inscrit en
    Décembre 2004
    Messages
    6 132
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 69
    Localisation : France, Haute Savoie (Rhône Alpes)

    Informations professionnelles :
    Activité : Retraité
    Secteur : Communication - Médias

    Informations forums :
    Inscription : Décembre 2004
    Messages : 6 132
    Par défaut
    Salut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    Dim MonFichier
    '................
    MonFichier.Text = CommonDialog1.FileName
    La variable MonFichier n'a pas de propriété Text cette variable n'est pas un objet.
    :whistle:pourquoi pas, pour remercier, un :plusser: pour celui/ceux qui vous ont dépannés.
    saut de ligne
    OOOOOOOOO👉 → → Ma page perso sur DVP ← ← 👈

  7. #7
    Membre émérite
    Inscrit en
    Décembre 2007
    Messages
    512
    Détails du profil
    Informations forums :
    Inscription : Décembre 2007
    Messages : 512
    Par défaut
    Bonjour,

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    Open "MonFichier" For Input As #1
    Si tu ouvres un fichier en 'INPUT , il faut prendre le code approprié
    pour le lire

    soit
    Mais attention s'il y a des virgules dans le texte...

    ou alors
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    Line input #1, chaine
    NB: PRINT, c'est pour écrire et on ouvre alors le fichier en OUTPUT ou APPEND

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

Discussions similaires

  1. Ouvrir avec enregistrements verrouillés
    Par mapmip dans le forum Access
    Réponses: 6
    Dernier message: 14/05/2007, 19h09
  2. Réponses: 2
    Dernier message: 24/04/2007, 08h03
  3. Ouvrir, écrire, enregistrer, modifier, créer un fichier .txt
    Par Omion dans le forum VB 6 et antérieur
    Réponses: 11
    Dernier message: 11/12/2006, 07h50
  4. Réponses: 6
    Dernier message: 21/09/2006, 16h08
  5. Ouvrire ou Enregistrer un Fichier Excel
    Par jo281 dans le forum ASP
    Réponses: 1
    Dernier message: 13/12/2005, 18h55

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