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

Scripts/Batch Discussion :

Découpage d'un fichier txt à partir d'une liste csv


Sujet :

Scripts/Batch

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Nouveau candidat au Club
    Inscrit en
    Avril 2013
    Messages
    2
    Détails du profil
    Informations forums :
    Inscription : Avril 2013
    Messages : 2
    Par défaut Découpage d'un fichier txt à partir d'une liste csv
    Bonjour,

    je vous fais grâce du laïus du débutant qui n'y arrive pas...

    Je souhaiterais générer des fichiers txt à partir d'un ENORME fichier data.txt dont chaque ligne commence par une clef
    Extrait du fichier data.txt (séparateur = " "):

    398227A111       AAE       E       XS100E       XS1001
    398227A112       AAE       E       XS100E       XS1002
    398227A113       AAE       E       XS100E       XS1003
    398227A114       AAE       E       XS100E       XS1004
    398227A115       AAE       E       XS100E       XS1005
    398227A116       AAE       E       XS100E       XS1006
    398227A117       AAE       E       XS100E       XS1007
    398227A118       AAE       E       XS100E       XS1008
    398227A119       AAE       E       XS100E       XS1009
    398227A120       AAE       E       XS1001010
    398227A121       AAE       E       XS1001011
    398227B122       AAE       E       XS1001012
    398227B123       AAE       E       XS1001013
    398227B124       AAE       E       XS1001014
    398227B125       AAE       E       XS1001015
    398228A669       AAE       E       XS1001016
    398228A670       AAE       E       XS1001017
    398228A671       AAE       E       XS1001018
    398228A672       AAE       E       XS1001019
    398228A673       AAE       E       XS1001020
    398228A674       AAE       E       XS1001021
    398228A675       AAE       E       XS1001022
    398228B676       AAE       E       XS1001023
    398228B677       AAE       E       XS1001024
    Je souhaiterais dispatcher ces données dans des fichiers différents en les triant sur la base des 6 premiers digits du code de début de ligne. Pour cela, j'ai généré une table liste.csv comme suit:
    4001;398227
    4002;398228
    4003;398229
    4004;398230
    4005;398231
    4006;398232
    L'objectif est donc d'obtenir des fichiers comme par exemple le fichier4001.txt qui contiendrait donc les lignes suivantes:
    398227A111       AAE       E       XS100E       XS1001
    398227A112       AAE       E       XS100E       XS1002
    398227A113       AAE       E       XS100E       XS1003
    398227A114       AAE       E       XS100E       XS1004
    398227A115       AAE       E       XS100E       XS1005
    398227A116       AAE       E       XS100E       XS1006
    398227A117       AAE       E       XS100E       XS1007
    398227A118       AAE       E       XS100E       XS1008
    398227A119       AAE       E       XS100E       XS1009
    398227A120       AAE       E       XS1001010
    398227A121       AAE       E       XS1001011
    398227B122       AAE       E       XS1001012
    398227B123       AAE       E       XS1001013
    398227B124       AAE       E       XS1001014
    398227B125       AAE       E       XS1001015
    Désolé, je suis un peu long mais c'est pour mieux définir la situation.
    J'ai donc essayé un batch à partir de ce que j'ai trouvé:

    Code Batch : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    for /f "tokens=1,2 delims=;" %%i in (liste.csv) do ( 
    	for /f "tokens=*" %%A in (data.txt) do (
    	findstr /b /c:'%%j' do (
    		echo %%A>>fichier%%i.txt
    		)
    	)
    )

    ...et ça marche pas!
    Un petit coup de main de pro serait le bienvenu!
    Fichiers attachés Fichiers attachés

  2. #2
    Membre Expert
    Femme Profil pro
    ..
    Inscrit en
    Décembre 2019
    Messages
    682
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 95
    Localisation : Autre

    Informations professionnelles :
    Activité : ..

    Informations forums :
    Inscription : Décembre 2019
    Messages : 682
    Par défaut
    Quelque chose dans ce genre

    Code Batch : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    for /f "tokens=1,2 delims=;" %%i in (liste.csv) do ( 
    	findstr "^%%j" data.txt > fichier%%i.txt
    )

    peut-être ?

  3. #3
    Nouveau candidat au Club
    Inscrit en
    Avril 2013
    Messages
    2
    Détails du profil
    Informations forums :
    Inscription : Avril 2013
    Messages : 2
    Par défaut
    Citation Envoyé par kaitlyn Voir le message
    Code Batch : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    for /f "tokens=1,2 delims=;" %%i in (liste.csv) do ( 
    	findstr "^%%j" data.txt > fichier%%i.txt
    )
    ...déjà au lycée, mon prof me disait "pourquoi faire simple quand on peut faire compliquer!"
    ...ok, pas besoin d'une seconde boucle FOR /F pour lire le fichier data.txt
    Bon...j'en conclue que findstr sans autre argument renvoie à la ligne entière? et/ou à quoi sert le ^ devant la variable?
    Enfin, la différence entre > et >> que j'ai trouvé dans des forum?

    Merci encore!

Discussions similaires

  1. [WD18] Ecrire dans un fichier txt à partir d'une requête SQL
    Par Blooster dans le forum WinDev
    Réponses: 4
    Dernier message: 29/05/2013, 11h03
  2. [Toutes versions] Traiter un fichier txt à partir d'une macro VBA Excel
    Par alaize dans le forum Macros et VBA Excel
    Réponses: 2
    Dernier message: 28/07/2011, 15h25
  3. Réponses: 0
    Dernier message: 15/11/2008, 21h53
  4. Réponses: 10
    Dernier message: 23/10/2007, 15h15
  5. Réponses: 8
    Dernier message: 07/09/2006, 11h43

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