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 :

Recherche sur fichier texte. [XL-2007]


Sujet :

Macros et VBA Excel

  1. #21
    Futur Membre du Club
    Femme Profil pro
    Ingénieur après-vente
    Inscrit en
    Octobre 2014
    Messages
    23
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 35
    Localisation : France, Bas Rhin (Alsace)

    Informations professionnelles :
    Activité : Ingénieur après-vente

    Informations forums :
    Inscription : Octobre 2014
    Messages : 23
    Points : 9
    Points
    9
    Par défaut
    c'est exactement ce que je voulais
    Merci Beaucoup PARMI de ta précieuse aide c'est très gentil de ta part

  2. #22
    Futur Membre du Club
    Femme Profil pro
    Ingénieur après-vente
    Inscrit en
    Octobre 2014
    Messages
    23
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 35
    Localisation : France, Bas Rhin (Alsace)

    Informations professionnelles :
    Activité : Ingénieur après-vente

    Informations forums :
    Inscription : Octobre 2014
    Messages : 23
    Points : 9
    Points
    9
    Par défaut
    Bonjour Parmi,
    Me Revoilà encore avec mes questions et je suis vraiment désolé,
    j'ai eu un petit souci sur un fichier; les données que je recherchais étaient classées sur deux voir trois lignes sur un fichier texte
    exemple:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     
    [in....
    .......
    ......fos]
    vue que ton code établi sa recherche en ligne/ligne, ces données ne sont pas prises compte.
    j'ai essayé de voir sur des tuto pour qu'il prend en compte la donnée du début jusqu'à la fin et ceux pour n ligne.
    est ce que ceci est faisable?
    Merci

  3. #23
    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
    Essaie comme ceci pour voir
    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
    Sub ExtraireTexte()
        Dim I As Long, J As Long
        Dim Fichier As Variant
        Dim strTemp As String, Chaine As String
        Dim Ligne As Long
        Dim Tablo As Variant
        Dim FF As Integer
     
        ChDrive "C"
        ChDir "C:\"
     
        Fichier = Application.GetOpenFilename("Fichiers Texte (*.txt),*.txt", MultiSelect:=True)
     
        If Not IsArray(Fichier) Then Exit Sub
     
        For I = 1 To UBound(Fichier)
            ActiveWorkbook.Sheets.Add after:=Worksheets(Worksheets.Count)
            ActiveSheet.Name = Right(Fichier(I), Len(Fichier(I)) - InStrRev(Fichier(I), "\"))
            Ligne = 1
            FF = FreeFile
            Open Fichier(I) For Input As #FF
                strTemp = Input(LOF(FF), #FF)   'charge tout le fichier
                Chaine = CleanString(strTemp)   'transforme la chaîne
                If Trim(Chaine) <> "" Then
                    Tablo = Split(Chaine, vbCrLf)
                    For J = 0 To UBound(Tablo)
                        Ligne = Ligne + 1
                        ActiveSheet.Range("A" & Ligne) = Tablo(J)
                    Next
                End If
     
            Close #FF
        Next
    End Sub
     
    Function CleanString(Chaine As String) As String
        Dim I As Long
        Dim Debut As Long, Fin As Long
        Dim strTemp As String
     
        Chaine = Replace(Chaine, vbCrLf, " ")
     
        For I = 1 To Len(Chaine)
            If Mid(Chaine, I, 1) = "[" Then Debut = I
            If Mid(Chaine, I, 1) = "]" Then Fin = I
            If Debut > 0 And Fin > 0 Then
                strTemp = strTemp & Mid(Chaine, Debut, Fin - Debut + 1) & vbCrLf
                Debut = 0: Fin = 0
            End If
        Next
        CleanString = strTemp
    End Function
    MPi²

  4. #24
    Futur Membre du Club
    Femme Profil pro
    Ingénieur après-vente
    Inscrit en
    Octobre 2014
    Messages
    23
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 35
    Localisation : France, Bas Rhin (Alsace)

    Informations professionnelles :
    Activité : Ingénieur après-vente

    Informations forums :
    Inscription : Octobre 2014
    Messages : 23
    Points : 9
    Points
    9
    Par défaut
    Merci beaucoup parmi de ton aide, tout marche à merveille

  5. #25
    Inactif  

    Homme Profil pro
    cuisiniste
    Inscrit en
    Avril 2009
    Messages
    15 379
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Var (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : cuisiniste
    Secteur : Bâtiment

    Informations forums :
    Inscription : Avril 2009
    Messages : 15 379
    Points : 12 075
    Points
    12 075
    Billets dans le blog
    8
    Par défaut heu
    Bonjour
    ayant regardé le resultat souhaité pour moi il y avait beaucoup plus simple

    exemple avec un 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
    Sub test1()
        Dim File As Object, fso As Object, result As Variant, tablo As Variant, a As Long, fichier As String, newsheet As Worksheet
        fichier = "C:\Users\polux\Desktop\Nouveau dossier\exemple.txt"
            Set newsheet = Sheets.Add(After:=Sheets(Sheets.Count))
           newsheet.name = Split(fichier, "\")(UBound(Split(fichier, "\")))
           Set fso = CreateObject("Scripting.FileSystemObject")
        Set File = fso.OpenTextFile(fichier, 1, True)
            texte = File.Readall
        result = Split(texte, "[")
        ReDim tablo(UBound(result) * 2, 1)
        a = 1
        For I = 1 To UBound(result)
            tablo(a, 0) = "[" & Split(result(I), "]")(0) & "]"
            a = a + 2
        Next
        newsheet.Range("A1").Resize(UBound(tablo)) = tablo
    End Sub
    il te suffirait mettre ce code dans une boucle sur la fonction "DIR" sur un dossier pour faire tout le dossier
    Marc va encore me traiter de maniaque de la fonction "SPLIT"
    mes fichiers dans les contributions:
    mail avec CDO en vba et mail avec CDO en vbs dans un HTA
    survol des bouton dans userform
    prendre un cliché d'un range

    si ton problème est résolu n'oublie pas de pointer : : ça peut servir aux autres
    et n'oublie pas de voter

  6. #26
    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




    Pas du tout Patrick !

    Et je serais mal placé car moi aussi j'en suis adepte !

    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)

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

Discussions similaires

  1. [VBA-E] Calcul sur fichiers Texte
    Par anisr dans le forum Macros et VBA Excel
    Réponses: 9
    Dernier message: 04/02/2007, 14h37
  2. Réponses: 2
    Dernier message: 29/05/2006, 09h54
  3. [VB.NET]Problème de lecture et écriture sur fichier texte
    Par zouhib dans le forum Windows Forms
    Réponses: 25
    Dernier message: 23/05/2006, 15h30
  4. Réponses: 11
    Dernier message: 17/05/2006, 10h48
  5. problème sur fichier texte
    Par vivelesgnous dans le forum Général Python
    Réponses: 6
    Dernier message: 26/04/2006, 20h08

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