Bonjour à tous et bonne et heureuse année
J'ai des fichiers .txt qui sont trop important pour les importer avec excel 2016 (fichier de 600M)
Avec le code suivant j'arrive à tronçonner un fichier en utilisant le nb maxi de ligne possible
Pouvez-vous me dire si il est possible avec ce bout de code de créer des nouveaux fichiers pour chacune des feuilles et qui reprendrait le nom du fichier d'origine avec un indice ? ( _001.txt type split)
Merci d'avance
J'ai des fichiers .txt qui sont trop important pour les importer avec excel 2016 (fichier de 600M)
Avec le code suivant j'arrive à tronçonner un fichier en utilisant le nb maxi de ligne possible
Pouvez-vous me dire si il est possible avec ce bout de code de créer des nouveaux fichiers pour chacune des feuilles et qui reprendrait le nom du fichier d'origine avec un indice ? ( _001.txt type split)
Merci d'avance
VB:
Sub Extraction_V2()
Dim Repertoire As String, Fichier As String
Dim strFullName As Variant
Dim Cn As Object, Rs As Object
'Sélection du ficher
strFullName = Application.GetOpenFilename("Fichiers textes (*.txt),*.txt", , _
"Sélectionnez un fichier :")
'On sort si aucun fichier n'est sélectionné
If strFullName = False Then Exit Sub
Application.ScreenUpdating = False
Fichier = Dir(strFullName)
Repertoire = Left(strFullName, Len(strFullName) - (Len(Fichier) + 1))
'Connection
Set Cn = CreateObject("ADODB.Connection")
Cn.Open "Provider=Microsoft.Jet.OLEDB.4.0;" & _
"Data Source=" & Repertoire & ";" & _
"Extended Properties=""text;HDR=Yes;FMT=Delimited"""
'Requete
Set Rs = CreateObject("ADODB.Recordset")
Rs.Open "SELECT * FROM [" & Fichier & "]", Cn, 3, 1, 1
'boucle sur le résultat de la requete
While Not Rs.EOF
'Ajout Feuille
Worksheets.Add
'Ecriture des données dans la feuille
'65536 spécifie le nombre de lignes par feuille
ActiveSheet.Range("A1").CopyFromRecordset Rs, 10000000
Wend
Rs.Close
Set Rs = Nothing
Cn.Close
Set Cn = Nothing
Application.ScreenUpdating = True
End Sub