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

VBA Access Discussion :

Lire un fichier et écrire dans un autre fichier [AC-2010]


Sujet :

VBA Access

  1. #1
    Mut
    Mut est déconnecté
    Membre averti Avatar de Mut
    Homme Profil pro
    Inscrit en
    Mars 2003
    Messages
    931
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 41
    Localisation : France, Seine Maritime (Haute Normandie)

    Informations forums :
    Inscription : Mars 2003
    Messages : 931
    Points : 307
    Points
    307
    Par défaut Lire un fichier et écrire dans un autre fichier
    Bonjour,

    Je suis un peu perdu dans mes boucles.

    Pour résumé, je dois ouvrir x fichiers, les parcourirs et une fois le traitement du parcours terminé, écrire dans un nouveau fichier les valeurs récupérées.Puis passer au fichier x+1

    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
     
     
    dim ifile, intfic as interger
     
    ifile=freefile
    intfic=freefile
     
    for indtab=0 to ubound(tabfichiers())
     
    NomFichier=TabFichiers(indtab)
     
    open NomFichier for binary access read lock read as ifile
     
    do while not eof(ifile)
    Line Input #ifile, Laligne
    'code récupération d'une valeur
     
    loop
     
    open CheminFichier for output as intfic
     
    print #intfic, DonneRecup
     
    Close #intfic
     
    close #ifile
     
    next indtab

    Mais cela ne fonctionne pas, il me crée qu'un fichier alors que la boucle next parcours bien tout les fichiers source

  2. #2
    Modérateur

    Homme Profil pro
    Inscrit en
    Octobre 2005
    Messages
    15 345
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Canada

    Informations forums :
    Inscription : Octobre 2005
    Messages : 15 345
    Points : 23 805
    Points
    23 805
    Par défaut
    C'est normal car ton Open Output efface le contenu du fichier existant.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    open CheminFichier for append
    Qui va forcer l'ajout à la fin du fichier existant. Évidement au début du traitement il faut supprimer le fichier résultat sinon tu vas te rerpouvre avec tous les résultats de tous tes traitements mis bout à bout :o). Le append va créer le fichier si il n'existe pas.

    A+
    Vous voulez une réponse rapide et efficace à vos questions téchniques ?
    Ne les posez pas en message privé mais dans le forum, vous bénéficiez ainsi de la compétence et de la disponibilité de tous les contributeurs.
    Et aussi regardez dans la FAQ Access et les Tutoriaux Access. C'est plein de bonnes choses.

  3. #3
    Mut
    Mut est déconnecté
    Membre averti Avatar de Mut
    Homme Profil pro
    Inscrit en
    Mars 2003
    Messages
    931
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 41
    Localisation : France, Seine Maritime (Haute Normandie)

    Informations forums :
    Inscription : Mars 2003
    Messages : 931
    Points : 307
    Points
    307
    Par défaut
    Bonjour,

    Oui effectivement, j'avais un probleme de mode d'ouverture de fichier également... Mais le problème le plus ennuyant est la détection de la fin du fichier car malgré ma boucle eof, j'ai une erreur de dépassement de fichier dûe certainement à l'accés binaire...comment puis-je faire autrement qu'avec la boucle EOF ?

    Merci

  4. #4
    Modérateur

    Homme Profil pro
    Inscrit en
    Octobre 2005
    Messages
    15 345
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Canada

    Informations forums :
    Inscription : Octobre 2005
    Messages : 15 345
    Points : 23 805
    Points
    23 805
    Par défaut
    Pour faire un accès binaire il faut utiliser un truc du genre

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    dim t as string * 1 'Défini un tampon de 1 caractère
     
    do while LOC(numFicBinaire) <= lof(numFicBinaire)
      'lit les données tant que la position courante est inférieure ou égale à la longueur du fichier en octets.
      get numficBinaire,,t  'lit une longueur de tampon à la fois
      'ici ton code
    loop
    A+
    Vous voulez une réponse rapide et efficace à vos questions téchniques ?
    Ne les posez pas en message privé mais dans le forum, vous bénéficiez ainsi de la compétence et de la disponibilité de tous les contributeurs.
    Et aussi regardez dans la FAQ Access et les Tutoriaux Access. C'est plein de bonnes choses.

  5. #5
    Mut
    Mut est déconnecté
    Membre averti Avatar de Mut
    Homme Profil pro
    Inscrit en
    Mars 2003
    Messages
    931
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 41
    Localisation : France, Seine Maritime (Haute Normandie)

    Informations forums :
    Inscription : Mars 2003
    Messages : 931
    Points : 307
    Points
    307
    Par défaut
    Parfait, merci beaucoup ça fonctionne mieux

    Merci

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

Discussions similaires

  1. Réponses: 1
    Dernier message: 11/08/2011, 08h26
  2. Réponses: 2
    Dernier message: 14/02/2011, 19h30
  3. Lire une cellule dans un autre fichier
    Par jurgh dans le forum Macros et VBA Excel
    Réponses: 3
    Dernier message: 08/09/2009, 17h22
  4. Réponses: 6
    Dernier message: 31/08/2006, 15h19
  5. Réponses: 1
    Dernier message: 24/11/2004, 16h54

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