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 :

Supprimer un fichier si non listé dans un autre fichier [Batch]


Sujet :

Scripts/Batch

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Candidat au Club
    Homme Profil pro
    Consultant informatique
    Inscrit en
    Septembre 2015
    Messages
    3
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Pas de Calais (Nord Pas de Calais)

    Informations professionnelles :
    Activité : Consultant informatique

    Informations forums :
    Inscription : Septembre 2015
    Messages : 3
    Par défaut Supprimer un fichier si non listé dans un autre fichier
    Bonjour à tous,

    Tout d'abord merci à ceux qui prendront la peine de me répondre.

    Expression du besoin :

    J'ai un répertoire dans lequel il existe des fichiers "MonFichier.XXX.YYYYYYYY" XXX étant un chiffre sur 3 caractères correspondant à des numéros de postes et YYYYYYYY étant une date au formate YYYYMMDD

    Dans un fichier texte, placé dans le même répertoire, j'ai un fichier (appelé "liste_poste.txt") qui contient la liste de tous les postes référencées en base de données.

    J'ai donc, un batch qui permet l'exécution d'un fichier SQL, qui lui même effectue un spool de la liste de mes postes vers mon fichier "liste_poste.txt".

    Ce que j'ai besoin de faire c'est vérifier, tous les jours, s'il existe, dans mon répertoire un fichier "MonFichier.XXX.YYYYYYYY" qui ne serait pas référencé dans mon fichier "liste_poste.txt". Si t'el est le cas, alors il me faut supprimer le dit fichier.

    Pour résumé, j'ai donc un fichier Liste_poste.txt rempli de la maniére suivante :

    001
    002
    004
    034
    174

    dans le répertoire de ce fichier txt j'ai des fichiers :

    MonFichier.001.YYYYYYYY
    MonFichier.002.YYYYYYYY
    MonFichier.003.YYYYYYYY
    etc...

    Dans l'exemple ci-dessus, le traitement doit détecter que mon fichier "MonFichier.003.YYYYYYYY" n'est pas référencé dans le fichier "liste_poste.txt" et donc le supprimer.

    J'ai tenté de faire une boucle for imbriquée dans une autre mais je galéres un peu et n'obtiens jamais le résultat attendu.

    Je sollicite donc votre aide.

    D'avance merci à vous.

    Cdt,
    Rabibou

  2. #2
    Membre émérite Avatar de devilsnake88
    Homme Profil pro
    Technicien maintenance
    Inscrit en
    Janvier 2013
    Messages
    453
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Technicien maintenance
    Secteur : High Tech - Matériel informatique

    Informations forums :
    Inscription : Janvier 2013
    Messages : 453
    Par défaut
    Bonjour,
    Essaye ceci:
    Code bat : 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
    @echo off&cls
     
    set liste=liste_poste.txt
     
    for /r . %%a in (*.*) do (
        type "%liste%" | find "%%~na" > nul
        if ErrorLevel 1 (
            if not "%%~nxa"=="%~nx0" (
                if not "%%~nxa"=="%liste%" (
                    echo On supprime %%~nxa
                    REM del %%~nxa /F /S /Q
                )
            )
        )
    )
    pause
    exit

  3. #3
    Candidat au Club
    Homme Profil pro
    Consultant informatique
    Inscrit en
    Septembre 2015
    Messages
    3
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Pas de Calais (Nord Pas de Calais)

    Informations professionnelles :
    Activité : Consultant informatique

    Informations forums :
    Inscription : Septembre 2015
    Messages : 3
    Par défaut
    Bonjour devilsnake88,

    Et merci d'avour pris le temps de me répondre.

    Il a fallu que j'applique quelques modifications à ton bout de code et au mien pour pouvoir utiliser ta solution mais celle-ci fonctionne, désormais, parfaitement.

    En jouant ton script tel quel, la commande m'aurait supprimer l'intégralité des fichiers contenu dans le répertoire. A mon sens, normal, puisqu'on recherche une chaine de caractére ex : MonFichier.001.YYYYYYYY dans un fichier qui contient des chaines de caratéres ex : 001

    Voici les modifications que j'ai apporté :

    1er modification :

    Boucle for permettant de reformaliser le fichier Liste_mag.txt afin qu'il contienne désormais, non plus, 001 mais MonFichier.001

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    for /F "Tokens=1,2,3 delims=."  %%a in (Liste_mag.txt) do echo MonFichier.%%a >> Liste_mag_formalise.txt
    2eme modification :

    Boucle for permettant d'insérer, dans un fichier formalisé la liste des fichiers MonFichier.XXX.YYYYYYYY que je trouve dans mon répertoire mais syntaxé de la maniére suivante : MonFichier.XXX

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    for /F "Tokens=1,2,3 delims=."  %%a in ('Dir /b/o "MonChemin\MonFichier.???.????????"') do echo %%a.%%b >> Liste_MonFichier_formalise.txt
    3eme modification

    Adaptation de la commande que tu m'a fournis qui donne donc ceci :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    set liste=liste_mag_formalise.txt
    set MonFichier=Liste_MonFichier_formalise.txt
    
    for /F %%a in (%MonFichier%) do (
        type "%liste%" | find "%%a" > nul
        if ErrorLevel 1 (
            Del /Q "MonChemin\%%a.*"
       )
    )

    Je ne sais pas si c'est la meilleure solution et/ou la plus rapide et/ou la plus simple mais en tout cas, ça marche.

    Par conséquent, un grand merci à toi devilsnake88

    Cdt,
    Rabibou

  4. #4
    Nouveau candidat au Club
    Homme Profil pro
    Administrateur de base de données
    Inscrit en
    Septembre 2015
    Messages
    2
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 48
    Localisation : France, Jura (Franche Comté)

    Informations professionnelles :
    Activité : Administrateur de base de données

    Informations forums :
    Inscription : Septembre 2015
    Messages : 2
    Par défaut problème similaire, je n'arrive pas à adapter ...
    Bonjour,
    j'ai un problème très proche je pense :
    1- je veux supprimer 300 fichiers parmi 1000 dans un répertoire /test/
    2- la liste de ces 300 fichiers est dans un fichier csv : /test/supprimer.csv
    Quel script écrire pour supprimer ces fichiers ?
    j'ai essayé d'adapter le script de cette page ... mais rien n'y fait !
    MERCI

  5. #5
    Candidat au Club
    Homme Profil pro
    Consultant informatique
    Inscrit en
    Septembre 2015
    Messages
    3
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Pas de Calais (Nord Pas de Calais)

    Informations professionnelles :
    Activité : Consultant informatique

    Informations forums :
    Inscription : Septembre 2015
    Messages : 3
    Par défaut
    Bonjour TENREV39

    JE pense qu'avec le ptit bout de code ci-dessous, tu devrais pouvoir t'en sortir

    Attention, je pars du principe que dans ton fichier supprimer.csv tu as un nom de fichier par ligne.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    
    @echo off
    cls
    
    For /f %%i in (C:\test\supprimer.csv) do (
             echo %%i va etre supprimer
             pause
             del /Q "C:\test\%%i"
    )
    Je viens de tester sur mon poste, ça fonctionne bien.

    Cdt,
    Rabibou

  6. #6
    Nouveau candidat au Club
    Homme Profil pro
    Administrateur de base de données
    Inscrit en
    Septembre 2015
    Messages
    2
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 48
    Localisation : France, Jura (Franche Comté)

    Informations professionnelles :
    Activité : Administrateur de base de données

    Informations forums :
    Inscription : Septembre 2015
    Messages : 2
    Par défaut
    Citation Envoyé par rabibou Voir le message
    Bonjour TENREV39

    JE pense qu'avec le ptit bout de code ci-dessous, tu devrais pouvoir t'en sortir

    Attention, je pars du principe que dans ton fichier supprimer.csv tu as un nom de fichier par ligne.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    
    @echo off
    cls
    
    For /f %%i in (C:\test\supprimer.csv) do (
             echo %%i va etre supprimer
             pause
             del /Q "C:\test\%%i"
    )
    Je viens de tester sur mon poste, ça fonctionne bien.

    Cdt,
    Rabibou
    Super ! merci beaucoup Rabibou !!!!

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. Réponses: 1
    Dernier message: 01/08/2013, 18h23
  2. Intégrer des fichiers .java non compilés dans un autre programme
    Par getrude dans le forum EDI et Outils pour Java
    Réponses: 18
    Dernier message: 20/04/2012, 16h59
  3. Réponses: 0
    Dernier message: 28/02/2011, 13h48
  4. [Batch] Parcourir une liste dans un autre fichier
    Par jepasderemy dans le forum Scripts/Batch
    Réponses: 5
    Dernier message: 22/10/2009, 09h49
  5. Réponses: 1
    Dernier message: 20/08/2007, 10h25

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