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 :

modification ou renommage de plusieurs fichiers


Sujet :

Scripts/Batch

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre confirmé
    Femme Profil pro
    Ingénieur systèmes et réseaux
    Inscrit en
    Mai 2015
    Messages
    61
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 34
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations professionnelles :
    Activité : Ingénieur systèmes et réseaux
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Mai 2015
    Messages : 61
    Par défaut modification ou renommage de plusieurs fichiers
    Bonjour,

    Je me permets de vous écrire, que je souhaite faire un script qui permet de modifier le nom des plusieurs fichiers dans même répertoire.
    Pa exemple:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    cat facture*
    
    facture1date20171012.csv
    montant 20euro date 20180101
    facture2date20171012.csv
    montant 30euro date 20180102
    facture3date20171012.csv
    montant 20euro date 20180103
    facture4date20171012.csv
    montant 20euro date 20180104
    Je souhaite obtenir la date qui est à l'intérieur du fichier et de la mettre dans le nom du fichier à la place de l'ancienne date 20171012 comme ceci:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    facture1date20180101.csv
    facture2date20180102.csv
    facture3date20180103.csv
    facture4date20180104.csv
    J'ai commencé par lister d'abord les fichiers et pour récupérer la bonne de la date souhaité, après je ne sais plus quoi faire :/
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    for i in `ls`; do
    echo $i
    cat $i | head -1 | awk '{print $4}'
    done
    j'ai eu le résultat suivant de ce script:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    facture1date20171012.csv
    20180101
    facture2date20171012.csv
    20180102
    facture3date20171012.csv
    20180104
    facture4date20171012.csv
    20180103
    Merci par avance de votre aide.

  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,
    Que donne 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
    setlocal enabledelayedexpansion
    for /f "delims=" %%a in (list.txt) do (
        set "ligne=%%a"
        if "!ligne:~0,7!" equ "facture" (
            set "facture=!ligne!"
            set "facturedate=!facture:~0,-12!"
            set "extension=%%~xa"
        )
        if "!ligne:~0,7!" equ "montant" (
            set "montant=!ligne!"
            set "montantdate=!montant:~-8!"
            echo !facturedate!!montantdate!!extension!
        )
    )
    pause
    exit

    Ça me retourne bien:

    facture1date20180101.csv
    facture2date20180102.csv
    facture3date20180103.csv
    facture4date20180104.csv
    Le code n'est pas le plus propre au monde mais il fait le job.

  3. #3
    Membre confirmé
    Femme Profil pro
    Ingénieur systèmes et réseaux
    Inscrit en
    Mai 2015
    Messages
    61
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 34
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations professionnelles :
    Activité : Ingénieur systèmes et réseaux
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Mai 2015
    Messages : 61
    Par défaut
    Bonjour,

    Merci pour ton retour rapide, c'est gentil.

    J'a crée un fichier vide list.txt dans le même répértoire ou j'ai fichiers csv.
    Quand le lance le script .bat, j'ai eu le terminal cmd j'ai cliquer sur une touche, après rien n'est passé.

    Merci d'avance, Cdt,

  4. #4
    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
    Mon list.txt contenait simple ces lignes:
    cat facture*

    facture1date20171012.csv
    montant 20euro date 20180101
    facture2date20171012.csv
    montant 30euro date 20180102
    facture3date20171012.csv
    montant 20euro date 20180103
    facture4date20171012.csv
    montant 20euro date 20180104

Discussions similaires

  1. Réponses: 9
    Dernier message: 30/07/2016, 23h35
  2. [Excel] Modification de plusieurs fichiers excel
    Par July171292 dans le forum Bibliothèques et frameworks
    Réponses: 3
    Dernier message: 01/07/2015, 09h30
  3. [XL-2010] Macro Modification multiple sur plusieurs fichiers
    Par tbuhagiar dans le forum Macros et VBA Excel
    Réponses: 0
    Dernier message: 07/10/2013, 12h58
  4. Réponses: 2
    Dernier message: 05/05/2011, 09h30
  5. Réponses: 1
    Dernier message: 19/03/2008, 09h51

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