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

Macros et VBA Excel Discussion :

Code d'un fichier ASCII tabulé


Sujet :

Macros et VBA Excel

  1. #1
    Futur Membre du Club
    Femme Profil pro
    Conseil - Consultant en systèmes d'information
    Inscrit en
    Juillet 2014
    Messages
    11
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 37
    Localisation : Maroc

    Informations professionnelles :
    Activité : Conseil - Consultant en systèmes d'information
    Secteur : Finance

    Informations forums :
    Inscription : Juillet 2014
    Messages : 11
    Points : 7
    Points
    7
    Par défaut Code d'un fichier ASCII tabulé
    c'est quoi le code d'un fichier ASCII tabulé : d'un contenue fichier ASCII tabulé vers une feuille excel.
    est ce quel se résoudre de la même manière comme un fichier délimite?

    Merci pour votre collaboration

  2. #2
    Expert éminent sénior
    Avatar de Marc-L
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Avril 2013
    Messages
    9 468
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Hauts de Seine (Île de France)

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Avril 2013
    Messages : 9 468
    Points : 18 677
    Points
    18 677
    Par défaut




    Double-cliquer sur le fichier depuis l'Explorateur Windows pour commencer !

    Si cela ne convient pas, ouvrir le fichier manuellement depuis Excel et bien remplir l'Assistant de conversion !
    Et en utilisant le Générateur de macros, le code est livré sur un plateau ‼
    C'est parce que la vitesse de la lumière est plus rapide que celle du son que tant de gens paressent brillants avant d'avoir l'air con ! (Thomas Boishardy)

  3. #3
    Futur Membre du Club
    Femme Profil pro
    Conseil - Consultant en systèmes d'information
    Inscrit en
    Juillet 2014
    Messages
    11
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 37
    Localisation : Maroc

    Informations professionnelles :
    Activité : Conseil - Consultant en systèmes d'information
    Secteur : Finance

    Informations forums :
    Inscription : Juillet 2014
    Messages : 11
    Points : 7
    Points
    7
    Par défaut
    Bonjour Mr MARC L,
    Merci d'abord pour votre interet et réponse, mais est ce qu'il existe un code depuis marco?


    Double-cliquer sur le fichier depuis l'Explorateur Windows pour commencer !

    Si cela ne convient pas, ouvrir le fichier manuellement depuis Excel et bien remplir l'Assistant de conversion !
    Et en utilisant le Générateur de macros, le code est livré sur un plateau ‼[/INDENT][/QUOTE]

  4. #4
    Expert éminent sénior
    Avatar de kiki29
    Homme Profil pro
    ex Observeur CGG / Analyste prog.
    Inscrit en
    Juin 2006
    Messages
    6 132
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Finistère (Bretagne)

    Informations professionnelles :
    Activité : ex Observeur CGG / Analyste prog.

    Informations forums :
    Inscription : Juin 2006
    Messages : 6 132
    Points : 11 274
    Points
    11 274
    Par défaut
    Salut,Salam, une solution basique

    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
    Option Explicit
     
    Sub Tst()
    Dim Fichier As Variant
        ChDir ThisWorkbook.Path & "\"
        Fichier = Application.GetOpenFilename("Text Files (*.txt), *.txt")
        If Fichier <> False Then Lire Fichier
    End Sub
     
    Private Sub Lire(ByVal NomFichier As String)
    Dim sChaine As String
    Dim Ar() As String
    Dim i As Long
    Dim iRow As Long, iCol As Long
    Dim NumFichier As Integer
    Dim Separateur As String * 1
     
        '  Séparateur Tabulation
        Separateur = Chr(9)
     
        Feuil1.Cells.Clear
        NumFichier = FreeFile
        iRow = 1
     
        Open sNomFichier For Input As #NumFichier
            Do While Not EOF(NumFichier)
                iCol = 1
                Line Input #NumFichier, sChaine
                Ar = Split(sChaine, Separateur)
                For i = LBound(Ar) To UBound(Ar)
                    Feuil1.Cells(iRow, iCol) = Ar(i)
                    iCol = iCol + 1
                Next i
                iRow = iRow + 1
            Loop
        Close #NumFichier
    End Sub

  5. #5
    Futur Membre du Club
    Femme Profil pro
    Conseil - Consultant en systèmes d'information
    Inscrit en
    Juillet 2014
    Messages
    11
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 37
    Localisation : Maroc

    Informations professionnelles :
    Activité : Conseil - Consultant en systèmes d'information
    Secteur : Finance

    Informations forums :
    Inscription : Juillet 2014
    Messages : 11
    Points : 7
    Points
    7
    Par défaut
    Merci bcp pour votre collaboration.
    Svp pour notre cas on n'a pas a un séparateur ''/'' en code aussi vous avez met ''/'' mais il y a un espace comment je peux le traduire en code

    Voir le texte qu'on a:

    S10_1678 1969 Harley Davidson Ultimate Chopper Motorcycles 1:10 Min Lin Diecast 7933 48,81 95,70
    S10_1949 1952 Alpine Renault 1300 Classic Cars 1:10 Classic Metal Creations 7305 98,58 214,30
    S10_2016 1996 Moto Guzzi 1100i Motorcycles 1:10 Highway 66 Mini Classics 6625 68,99 118,94

  6. #6
    Expert confirmé
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Mai 2013
    Messages
    3 617
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Canada

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : Alimentation

    Informations forums :
    Inscription : Mai 2013
    Messages : 3 617
    Points : 5 912
    Points
    5 912
    Par défaut
    Bonjour,

    Dans le texte que tu as copié, il n'y a pas de tabulation...
    Est-ce voulu ?
    MPi²

  7. #7
    Expert éminent sénior
    Avatar de kiki29
    Homme Profil pro
    ex Observeur CGG / Analyste prog.
    Inscrit en
    Juin 2006
    Messages
    6 132
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Finistère (Bretagne)

    Informations professionnelles :
    Activité : ex Observeur CGG / Analyste prog.

    Informations forums :
    Inscription : Juin 2006
    Messages : 6 132
    Points : 11 274
    Points
    11 274
    Par défaut
    Meryem, pourrais-tu mettre en pièce jointe un échantillon de ton fichier texte ?

  8. #8
    Futur Membre du Club
    Femme Profil pro
    Conseil - Consultant en systèmes d'information
    Inscrit en
    Juillet 2014
    Messages
    11
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 37
    Localisation : Maroc

    Informations professionnelles :
    Activité : Conseil - Consultant en systèmes d'information
    Secteur : Finance

    Informations forums :
    Inscription : Juillet 2014
    Messages : 11
    Points : 7
    Points
    7
    Par défaut
    je veux dire espace au lieu de ; ou /

  9. #9
    Expert éminent sénior


    Profil pro
    Inscrit en
    Juin 2003
    Messages
    14 008
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2003
    Messages : 14 008
    Points : 20 038
    Points
    20 038
    Par défaut
    bonjour,

    utilise l'enregistreur de macro... et ouvre ton fichier directement avec excel tu auras une idée du code à écrire ...

  10. #10
    Futur Membre du Club
    Femme Profil pro
    Conseil - Consultant en systèmes d'information
    Inscrit en
    Juillet 2014
    Messages
    11
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 37
    Localisation : Maroc

    Informations professionnelles :
    Activité : Conseil - Consultant en systèmes d'information
    Secteur : Finance

    Informations forums :
    Inscription : Juillet 2014
    Messages : 11
    Points : 7
    Points
    7
    Par défaut
    Citation Envoyé par kiki29 Voir le message
    Meryem, pourrais-tu mettre en pièce jointe un échantillon de ton fichier texte ?
    Bonjour KIKI 29,
    Merci bcp pour votre interet et collaboration.
    Veuillez trouver ci joint le texte:

    PRB.txt

  11. #11
    Expert confirmé
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Mai 2013
    Messages
    3 617
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Canada

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : Alimentation

    Informations forums :
    Inscription : Mai 2013
    Messages : 3 617
    Points : 5 912
    Points
    5 912
    Par défaut
    Quel est le résultat escompté dans Excel ?

    Dans ton fichier, il y a des sauts de lignes à chaque section.
    Split pourrait être utilisé pour séparer ces sections.

    Voici un exemple pour écrire le véhicule en colonne A et le texte s'y rapportant en colonne B
    Il restera à ajuster les sauts de ligne et la largeur des colonnes
    Le texte du type de véhicule a 50 caractères de long

    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
    Sub Importer()
        Dim I As Long, Ligne As Long
        Dim Fichier As String
        Dim strTemp As String
        Dim Tablo
     
        Fichier = "C:\PRB.txt"
     
        Open Fichier For Binary As #1
        strTemp = Space$(LOF(1))
            Get #1, , strTemp
            Tablo = Split(strTemp, vbCrLf)
            For I = 0 To UBound(Tablo)
                Ligne = Ligne + 1
                Range("A" & Ligne) = Trim(Left(Tablo(I), 50))
                Range("B" & Ligne) = Trim(Right(Tablo(I), Len(Tablo(I)) - 50))
            Next
        Close #1
    End Sub
    MPi²

  12. #12
    Futur Membre du Club
    Femme Profil pro
    Conseil - Consultant en systèmes d'information
    Inscrit en
    Juillet 2014
    Messages
    11
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 37
    Localisation : Maroc

    Informations professionnelles :
    Activité : Conseil - Consultant en systèmes d'information
    Secteur : Finance

    Informations forums :
    Inscription : Juillet 2014
    Messages : 11
    Points : 7
    Points
    7
    Par défaut
    Bonjour,
    Merci bcp pour votre intérêt et reponse.

    Bien cordialement

Discussions similaires

  1. vitesse de lecture d'un fichier ascii
    Par yan dans le forum C++
    Réponses: 5
    Dernier message: 31/01/2006, 14h43
  2. [vba] Envoi de fichier ascii client Windows => server Lin
    Par kremvax dans le forum Général VBA
    Réponses: 3
    Dernier message: 28/11/2005, 12h00
  3. Récupérer le code d un Fichier HTML
    Par jean_bobi dans le forum Entrée/Sortie
    Réponses: 10
    Dernier message: 31/10/2005, 15h51
  4. lire un fichier ascii complexe
    Par alexum dans le forum C++
    Réponses: 9
    Dernier message: 16/02/2005, 09h05
  5. Import fichier ASCII dans une base
    Par pithier dans le forum Bases de données
    Réponses: 3
    Dernier message: 01/02/2005, 19h03

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