Microsoft 365 Importer certaines données d'un ou plusieurs fichiers txt dans des cellules d'une feuille Excel

FCMLE44

XLDnaute Impliqué
Bonjour

J'ai un ou plusieurs fichiers txt dans un répertoire.
Je souhaiterais ouvrir ces fichier et récupérer certaines données pour les mettre dans une feuille d'un fichier excel
Je sais que ca peut se faire en créant une boucle mais je vous avoue que je sèche un peu n'ayant jamais travaillé avec des fichiers txt

Je vous mets un exemple excel en pièce jointe
Je dois remonter le numéro de Sécu, les noms et prénoms et le montant

Quelqu'un aurait il une idée ?

Merci
 

Pièces jointes

  • Classeur2.xlsx
    44.4 KB · Affichages: 9

FCMLE44

XLDnaute Impliqué
Bon j'ai mieux regardé vos fichiers, testez ce fichier (2) avec cette macro :
VB:
Option Compare Text 'la casse est ignorée

Sub Importer()
Dim chemin$, fichier$, x%, montant As Boolean, texte$, civ, p%, n&, a(), deb%, fin%
chemin = ThisWorkbook.Path & "\"
fichier = Dir(chemin & "*.txt") '1er fichier txt du dossier
While fichier <> ""
    x = FreeFile
    Open chemin & fichier For Input As #x 'ouverture en lecture séquentielle
    montant = False
    While Not EOF(x)
        Line Input #x, texte
        texte = Replace(Replace(Replace(texte, "é", "é"), "è", "è"), "ê", "ê") 'épuration
        '---récupération du Montant à passer---
        If montant Then montant = False: If IsNumeric(texte) Then a(4, n) = CDbl(texte)
        '---nom---
        For Each civ In Array("Monsieur", "Madame", "Mademoiselle")
            p = InStr(texte, civ)
            If p Then
                n = n + 1
                ReDim Preserve a(1 To 4, 1 To n)
                a(1, n) = fichier
                deb = p + Len(civ)
                fin = InStr(texte, "Arrêt")
                If fin Then fin = fin - 1 Else fin = Len(texte)
                a(3, n) = Trim(Mid(texte, deb, fin - deb + 1))
                Exit For
            End If
        Next
        '---N°SS---
        p = InStr(texte, "SS :")
        If p Then
            deb = p + 4
            fin = Len(texte)
            a(2, n) = Trim(Mid(texte, deb, fin - deb + 1))
        End If
        '---Montant à passer---
        If texte = "Prestation complementaire" Then montant = True 'repérage
    Wend
    Close #x
    fichier = Dir 'fichier suivant
Wend
'---restitution---
With ActiveSheet 'à adapter
    If .FilterMode Then .ShowAllData 'si la feuille est filtrée
    With .[A2]
        If n Then .Resize(n, 4) = Application.Transpose(a) 'fonction limitée à 65536 lignes
        .Offset(n).Resize(Rows.Count - n - .Row + 1, 4).ClearContents 'RAZ en dessous
    End With
    .Columns.AutoFit 'ajustement largeurs
End With
End Sub
Lorsque je le lance j'ai ce débogage en pièce jointe
POurtant ils sont bien tous dans le même répertoire
 

Pièces jointes

  • Capture d’écran 2022-08-17 195837.jpg
    Capture d’écran 2022-08-17 195837.jpg
    34.2 KB · Affichages: 27

job75

XLDnaute Barbatruc
Ce n'est pas normal, votre version Excel a de sérieux problèmes, essayez quand même ce fichier (3) avec :
VB:
Option Compare Text 'la casse est ignorée

Sub Importer()
Dim chemin$, fichier$, x%, montant As Boolean, texte$, civ, p%, n&, a(), deb%, fin%
chemin = ThisWorkbook.Path & "\"
fichier = Dir(chemin) '1er fichier du dossier
While fichier <> ""
    If Right(fichier, 4) = ".txt" Then
        x = FreeFile
        Open chemin & fichier For Input As #x 'ouverture en lecture séquentielle
        montant = False
        While Not EOF(x)
            Line Input #x, texte
            texte = Replace(Replace(Replace(texte, "é", "é"), "è", "è"), "ê", "ê") 'épuration
            '---récupération du Montant à passer---
            If montant Then montant = False: If IsNumeric(texte) Then a(4, n) = CDbl(texte)
            '---nom---
            For Each civ In Array("Monsieur", "Madame", "Mademoiselle")
                p = InStr(texte, civ)
                If p Then
                    n = n + 1
                    ReDim Preserve a(1 To 4, 1 To n)
                    a(1, n) = fichier
                    deb = p + Len(civ)
                    fin = InStr(texte, "Arrêt")
                    If fin Then fin = fin - 1 Else fin = Len(texte)
                    a(3, n) = Trim(Mid(texte, deb, fin - deb + 1))
                    Exit For
                End If
            Next
            '---N°SS---
            p = InStr(texte, "SS :")
            If p Then
                deb = p + 4
                fin = Len(texte)
                a(2, n) = Trim(Mid(texte, deb, fin - deb + 1))
            End If
            '---Montant à passer---
            If texte = "Prestation complementaire" Then montant = True 'repérage
        Wend
        Close #x
    End If
    fichier = Dir 'fichier suivant
Wend
'---restitution---
With ActiveSheet 'à adapter
    If .FilterMode Then .ShowAllData 'si la feuille est filtrée
    With .[A2]
        If n Then .Resize(n, 4) = Application.Transpose(a) 'fonction limitée à 65536 lignes
        .Offset(n).Resize(Rows.Count - n - .Row + 1, 4).ClearContents 'RAZ en dessous
    End With
    .Columns.AutoFit 'ajustement largeurs
End With
End Sub
 

Pièces jointes

  • Classeur(3).xlsm
    21.1 KB · Affichages: 4

Discussions similaires

Réponses
10
Affichages
401

Statistiques des forums

Discussions
315 084
Messages
2 116 060
Membres
112 645
dernier inscrit
Acid Burn