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 :

Vérification d'une copie à partir d'un CSV


Sujet :

Scripts/Batch

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre averti
    Profil pro
    Inscrit en
    Mars 2008
    Messages
    30
    Détails du profil
    Informations personnelles :
    Âge : 41
    Localisation : France

    Informations forums :
    Inscription : Mars 2008
    Messages : 30
    Par défaut Vérification d'une copie à partir d'un CSV
    Bonjour, je viens encore vous soumettre un soucis (encore pire que le dernier)
    J'ai besoin de créer un batch (j'ai malheureusement assez peu de temps pour developper dans un autre langage, le batch étant celui que je connais le mieux).

    Ce batch doit faire plusieurs tâches.
    Je vais commencer par expliquer l'environnement de travail:
    Un applicatif externe vient déposer de nouveaux fichiers dans des repertoires (ces repertoires n'étant pas toujours les mêmes).
    J'ai besoin d'une appli qui me permettent de vérifier le bon dépot des fichiers.

    1-Un fichier CSV est crée par l'utilisateur (moi en l'occurrence) à partir d'un fichier Excel, ce fichier csv comprends les données suivantes:
    Répertoire - nom du fichier - version - date de modification -taille (en octets)

    2-Pour chaque ligne du fichier CSV, le programme récupere une variable pour chaque colonne(boucle For?), VarRep, VarNom,VarVers,VarDate,VarTaille.

    3-en faisant ensuite un dir VarRep/VarNom (toujours dans ma boucle!), j'aimerai sortir les variables VarDate1 et VarTaille1 et les comparer aux VarDate et VarTaille.

    4-Si il ya une différence, l'appli génére une ligne (comprenant les infos fichier et sur quelle variable est l'erreur) dans un fichier de log(et on reprend la boucle).

    5-Affichage du fichier de log


    Cette démarche vous parait elle possible? (je bloque un peu sur l'extraction des donnés du CSV)

    Merci de vos retours, je bosse sur une premiere version du code ..

  2. #2
    Membre Expert Avatar de Drizzt [Drone38]
    Homme Profil pro
    Directeur de projet
    Inscrit en
    Mai 2004
    Messages
    1 001
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 42
    Localisation : France, Isère (Rhône Alpes)

    Informations professionnelles :
    Activité : Directeur de projet

    Informations forums :
    Inscription : Mai 2004
    Messages : 1 001
    Par défaut
    1-Un fichier CSV est crée par l'utilisateur (moi en l'occurrence) à partir d'un fichier Excel, ce fichier csv comprends les données suivantes:
    Répertoire - nom du fichier - version - date de modification -taille (en octets)

    2-Pour chaque ligne du fichier CSV, le programme récupere une variable pour chaque colonne(boucle For?), VarRep, VarNom,VarVers,VarDate,VarTaille.
    Boucle FOR sur ton fichier en spécifiant les bon tokens.

    3-en faisant ensuite un dir VarRep/VarNom (toujours dans ma boucle!), j'aimerai sortir les variables VarDate1 et VarTaille1 et les comparer aux VarDate et VarTaille.
    Boucle FOR sur la commande dir. Idem les tokens qui vont bien sont tes amis (faudra trier un peu pour traiter que la ligne du fichier)

    4-Si il ya une différence, l'appli génére une ligne (comprenant les infos fichier et sur quelle variable est l'erreur) dans un fichier de log(et on reprend la boucle).
    IF, puis une redirection d'echo vers ton fichier log


    5-Affichage du fichier de log
    Type.

  3. #3
    Membre averti
    Profil pro
    Inscrit en
    Mars 2008
    Messages
    30
    Détails du profil
    Informations personnelles :
    Âge : 41
    Localisation : France

    Informations forums :
    Inscription : Mars 2008
    Messages : 30
    Par défaut
    merci de confirmer pour la boucle FOR
    J'essaye de voir ce que ca peut donner de mon coté, et je te tiens au courant

  4. #4
    Membre averti
    Profil pro
    Inscrit en
    Mars 2008
    Messages
    30
    Détails du profil
    Informations personnelles :
    Âge : 41
    Localisation : France

    Informations forums :
    Inscription : Mars 2008
    Messages : 30
    Par défaut
    bonjour, j'ai un peu du mal a me depaitouiller avec ma commande for

    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
    @echo off
    
    
    
    if EXIST d:\tempverif\  goto next
    mkdir D:\tempverif
    :next
    
    copy a:verif.csv D:\tempverif\
    
    Rem déclaration des variables
    set VarDir=0
    set VarNom=0
    Set VarTaille=0
    Set VarDate=0
    Set VarTaille1=0
    Set VarDate1=0
    
    setlocal enabledelayedexpansion
    
    FOR /F " tokens=1,2* delims=, " %i in (d:\tempverif\verif.csv) do echo %j% %k%
    la je suis juste sur la partie pour me sortir %j% et %k% (respectivement VarDir et VarNom) mais le programme plante au moment de la boucle for...
    et je ne vois pas pourquoi....

  5. #5
    Membre averti
    Profil pro
    Inscrit en
    Mars 2008
    Messages
    30
    Détails du profil
    Informations personnelles :
    Âge : 41
    Localisation : France

    Informations forums :
    Inscription : Mars 2008
    Messages : 30
    Par défaut
    bonjour
    Je suis toujours bloqué sur ma boucle for...j'ai essayé à partir d'un csv, d'un txt, rien de passe, le programme plante toujours

    en me référant à la doc for /?, j'ai établi que logiquement ma boucle devrait ressembler à cela

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    FOR /F " tokens=1,2 delims=; " %i in (d:\tempverif\verif.csv) do echo  %i% %j% %k%
    j'ai essayé en demandant d'afficher autre chose (echo yahoo), en mettant /enlebant des ' ou des " ou des (), mais rien n'y fait....

    Merci de votre aide

  6. #6
    Membre averti
    Profil pro
    Inscrit en
    Mars 2008
    Messages
    30
    Détails du profil
    Informations personnelles :
    Âge : 41
    Localisation : France

    Informations forums :
    Inscription : Mars 2008
    Messages : 30
    Par défaut
    OK, j'ai trouvé en executant via le dos , la bonne syntaxe (pour me sortir les valeurs qui m'interessent)

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    FOR /F " tokens=1,2 delims=; " %i in (d:\tempverif\verif.csv) do echo  %i %j
    en Commande Dos =>Ok
    dans mon batch NOK
    dans un batch vierge avec juste cette ligne (rien, même pas d'@echo off) =>NOK

    si qqn voit ce qui se passe....

Discussions similaires

  1. Réponses: 6
    Dernier message: 27/02/2009, 09h12
  2. Tracer une courbe à partir d'un fichier .csv
    Par dzonaser dans le forum MATLAB
    Réponses: 2
    Dernier message: 25/10/2008, 14h48
  3. Réponses: 2
    Dernier message: 10/07/2008, 15h14
  4. Réponses: 0
    Dernier message: 07/02/2008, 16h09
  5. Installer Windows XP pro à partir d'une copie physique
    Par samsso2006 dans le forum Windows XP
    Réponses: 1
    Dernier message: 11/10/2006, 15h03

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