logo Debian Debian Debian-France Debian-Facile Debian-fr.org Forum-Debian.fr Debian ? Communautés logo inclusivité

Debian-facile

Bienvenue sur Debian-Facile, site d'aide pour les nouveaux utilisateurs de Debian.

Vous n'êtes pas identifié(e).


L'icône rouge permet de télécharger chaque page du wiki visitée au format PDF et la grise au format ODT → ODT PDF Export

Différences

Ci-dessous, les différences entre deux révisions de la page.

Lien vers cette vue comparative

Les deux révisions précédentes Révision précédente
Prochaine révision
Révision précédente
Prochaine révision Les deux révisions suivantes
doc:systeme:find [19/09/2013 19:17]
MicP [Rechercher pour supprimer]
doc:systeme:find [17/07/2014 19:09]
smolski
Ligne 1: Ligne 1:
-====== ​Find ====== +====== ​find ======
- +
-(//testé// - **smolski** 26/08/2013) Le retour sur le forum est ici : [[http://​debian-facile.org/​viewtopic.php?​id=7310 | Lien vers le forum concernant ce tuto]] +
->​N'​hésitez pas à y faire part de vos remarques, succès, améliorations ou échecs !+
  
   * Objet : find   * Objet : find
-  * Niveau requis : DÉBUTANT +  * Niveau requis : {{tag>​avisé}} 
-  * Tags : +  * Commentaires : //Recherche ​de fichiers. // 
-  * Commentaires : //recherche ​de fichiers. // +  * Débutant, à savoir : [[:​doc:​systeme:​commandes:​le_debianiste_qui_papillonne|Utiliser GNU/Linux en ligne de commande, tout commence là !]] :-) 
-  * Débutant, à savoir : [[manuel:​le_debianiste_qui_papillonne|Utiliser GNU/Linux en ligne de commande, tout commence là !.]] :-)+  * Suivi : {{tag>​en-chantier à-tester à-placer}} - FIXME Pour choisir, voir les autres Tags possibles dans [[:​atelier:#​tags|l'​Atelier]]. 
 +    * Création par [[user>​smolski]] <​date>​ 
 +    * Testé par [[user>​smolski]] 26-08-2013 
 +  * Commentaires sur le forum [[http://​debian-facile.org/​viewtopic.php?​id=7310 | Lien vers le forum concernant ce tuto]]((N'​hésitez pas à y faire part de vos remarques, succès, améliorations ou échecs !)
 + 
 +**Nota :** 
 + 
 +Contributeurs,​ les FIXME sont là pour vous aider, supprimez-les une fois le problème corrigé ou le champ rempli !
  
 +===== Introduction =====
  
 Les exemples de ce tuto sont tous à faire en //user// sauf spécification. Les exemples de ce tuto sont tous à faire en //user// sauf spécification.
Ligne 16: Ligne 21:
  
 Par exemple, je voudrais chercher le log messages, mais je sais pas où se trouve ce fichier, faites : Par exemple, je voudrais chercher le log messages, mais je sais pas où se trouve ce fichier, faites :
-<​code ​bash>+<​code ​user>
 find / -name '​messages'</​code>​ find / -name '​messages'</​code>​
  
-<code+<file bash résultat de la commande précédente>  
-/​var/​log/​messages</​code>+/​var/​log/​messages</​file>
  
 Voilà la réponse : \\ Voilà la réponse : \\
Ligne 43: Ligne 48:
  
 Exemple simple : comment trouver un fichier portant le nom ''​note''​ ? Exemple simple : comment trouver un fichier portant le nom ''​note''​ ?
-<​code ​bash>+<​code ​user>
 find / -name '​note'</​code>​ find / -name '​note'</​code>​
  
Ligne 52: Ligne 57:
  
 Après un long délai d'​attente,​ la recherche se faisant dans toute l'​arborescence de la partition, la réponse fini par venir : Après un long délai d'​attente,​ la recherche se faisant dans toute l'​arborescence de la partition, la réponse fini par venir :
-   /​home/​martin/​note+<file bash résultat de la commande précédente>​  
 +/​home/​martin/​note</​file>​
  
 Si l'on n'est pas sûr de la "​casse"​ (Majuscule ou Minuscule) on utilise l'​option ''​-iname''​. Si l'on n'est pas sûr de la "​casse"​ (Majuscule ou Minuscule) on utilise l'​option ''​-iname''​.
Ligne 61: Ligne 67:
  
 Pour chercher tous les fichiers commençant par //note// et définir à partir de quel répertoire on souhaite effectuer la recherche on utilise cette syntaxe : Pour chercher tous les fichiers commençant par //note// et définir à partir de quel répertoire on souhaite effectuer la recherche on utilise cette syntaxe :
-<​code ​bash>+<​code ​user>
 find /​home/​martin -name '​note*'</​code>​ find /​home/​martin -name '​note*'</​code>​
  
Ligne 69: Ligne 75:
  
 Je cherche à trouver les répertoires archives dans /​media/​homebis. Je cherche à trouver les répertoires archives dans /​media/​homebis.
-Première chose à noter, il peut-être nécessaire de se mettre en [[commande:su|root]] pour avoir accès à tous les répertoires. +Première chose à noter, il peut-être nécessaire de se mettre en [[:​doc:​systeme:su|root]] pour avoir accès à tous les répertoires. 
-<​code ​bash>+<​code ​user>
 find /​media/​homebis -type d -name '​archives'</​code>​ find /​media/​homebis -type d -name '​archives'</​code>​
  
Ligne 79: Ligne 85:
  
 La réponse : La réponse :
 +<file bash résultat de la commande précédente> ​
   /​media/​homebis/​martin/​textes/​mes_archives/​Baseball/​archives   /​media/​homebis/​martin/​textes/​mes_archives/​Baseball/​archives
   /​media/​homebis/​martin/​archives   /​media/​homebis/​martin/​archives
Ligne 84: Ligne 91:
   /​media/​homebis/​Documents_gr/​archives   /​media/​homebis/​Documents_gr/​archives
   /​media/​homebis/​Documents_gr/​mes_fichiers/​archives   /​media/​homebis/​Documents_gr/​mes_fichiers/​archives
 +</​file>​
  
 Autre exemple un peu plus complexe cette fois. \\ Autre exemple un peu plus complexe cette fois. \\
Ligne 93: Ligne 101:
 ==== Première façon : ==== ==== Première façon : ====
  
-<​code ​bash>+<​code ​user>
 find /​home/​martin/ ​ \( -name '​*.mp3'​ -o -name '​*.ogg'​ \)</​code>​ find /​home/​martin/ ​ \( -name '​*.mp3'​ -o -name '​*.ogg'​ \)</​code>​
  
Ligne 102: Ligne 110:
  
 Une autre manière d'​écrire la commande ci-dessus est la suivante : Une autre manière d'​écrire la commande ci-dessus est la suivante :
-<​code ​bash>+<​code ​user>
 find -type f -name "​*.mp3"​ -o -name "​*.ogg"</​code>​ find -type f -name "​*.mp3"​ -o -name "​*.ogg"</​code>​
  
 Si je tape cette commande en étant dans mon répertoire /​home/​martin,​ le résultat sera une liste de fichiers ./.... \\ Si je tape cette commande en étant dans mon répertoire /​home/​martin,​ le résultat sera une liste de fichiers ./.... \\
-Il est intéressant de savoir que l'on peut étendre la recherche aux fichiers mp3 et mp4 en remplaçant le 3 par un ?((Voir : [[manuel:​regexp]])). La commande deviendrait donc : +Il est intéressant de savoir que l'on peut étendre la recherche aux fichiers mp3 et mp4 en remplaçant le 3 par un ?((Voir : [[:​doc:​programmation:​shell:​regexp]])). La commande deviendrait donc : 
-<​code ​bash>+<​code ​user>
 find -type f -name "​*.mp?"​ -o -name "​*.ogg"</​code>​ find -type f -name "​*.mp?"​ -o -name "​*.ogg"</​code>​
  
 ===== Rechercher pour supprimer ===== ===== Rechercher pour supprimer =====
- 
  
 Un fonction intéressante de //find// est de supprimer en lot les fichiers trouvés. Un fonction intéressante de //find// est de supprimer en lot les fichiers trouvés.
Ligne 120: Ligne 127:
  
 Exemple, si dans votre home ou autre dossier vous avez beaucoup de fichier .tar.gz qui ne vous servent plus à rien. Il suffit de lancer la commande suivante : Exemple, si dans votre home ou autre dossier vous avez beaucoup de fichier .tar.gz qui ne vous servent plus à rien. Il suffit de lancer la commande suivante :
-<​code ​bash>find -iname "​*.tar.gz"​ -delete</​code>​+<​code ​user>find -iname "​*.tar.gz"​ -delete</​code>​
  
 <note important>​**Attention,​ la fonction -delete ne vous demande pas de confirmation**</​note>​ <note important>​**Attention,​ la fonction -delete ne vous demande pas de confirmation**</​note>​
 +
 +=== Supprimer avec demande de confirmation ===
  
 Pour une demande de confirmation avant suppression de chaque fichier "​.tar.gz"​ trouvés : Pour une demande de confirmation avant suppression de chaque fichier "​.tar.gz"​ trouvés :
-<​code ​bash>find -iname "​*.tar.gz"​ -ok rm {} \;</​code>​ +<​code ​user>find -iname "​*.tar.gz"​ -ok rm {} \;</​code>​ 
- --- //[[|david96]] 12/09/2013 21:15//+Merci à [[http://​debian-facile.org/viewtopic.php?​pid=67484#​p67484|MicP]] pour cette trouvaille ​:
 ===== Filtrer en fonction des droits ===== ===== Filtrer en fonction des droits =====
  
Ligne 134: Ligne 144:
 Voici par exemple comment obtenir la liste de tout les fichiers dans le repertoire ''/​bin''​ qui ont le ''​bit setuid valant 1''​ : Voici par exemple comment obtenir la liste de tout les fichiers dans le repertoire ''/​bin''​ qui ont le ''​bit setuid valant 1''​ :
  
-<​code ​bash+<​code ​user
-find /bin -perm /5000 -user root<​code>​ +find /bin -perm /5000 -user root</code> 
-<code>+<file bash résultat de la commande précédente>
 /bin/su /bin/su
 /bin/mount /bin/mount
Ligne 142: Ligne 152:
 /bin/ping /bin/ping
 /bin/ping6 /bin/ping6
-</code>+</file>
  
 Cette option est intéressante pour la sécurité. Les fichiers listés dans la commande précédente sont tous exécuté avec les droits ''​root''​. Cette option est intéressante pour la sécurité. Les fichiers listés dans la commande précédente sont tous exécuté avec les droits ''​root''​.
Ligne 148: Ligne 158:
 ===== Recherche par motif ===== ===== Recherche par motif =====
  
-Pour rechercher un motif, il faut utiliser la même option, et utiliser les [[commande:regexp | REGEXP]].+Pour rechercher un motif, il faut utiliser la même option, et utiliser les [[:​doc:​programmation:​shell:regexp | REGEXP]].
  
 Voici par exemple la recherche de tous les fichiers terminant par ''​.java''​ dans le dossier courant: Voici par exemple la recherche de tous les fichiers terminant par ''​.java''​ dans le dossier courant:
  
-<​code ​bash+<​code ​user
-find . -name '​*.java'<​code>​ +find . -name '​*.java'<​/code> 
-<code>+<file bash résultat de la commande précédente
 ./​java/​jdk1.5.0_06/​demo/​applets/​Animator/​Animator.java ./​java/​jdk1.5.0_06/​demo/​applets/​Animator/​Animator.java
 ./​java/​jdk1.5.0_06/​demo/​applets/​ArcTest/​ArcTest.java ./​java/​jdk1.5.0_06/​demo/​applets/​ArcTest/​ArcTest.java
Ligne 161: Ligne 171:
 ./​java/​jdk1.5.0_06/​demo/​applets/​CardTest/​CardTest.java ./​java/​jdk1.5.0_06/​demo/​applets/​CardTest/​CardTest.java
 ... ...
 +</​file>​
 +
 +===== Rechercher les fichiers n'​appartenant pas à l'​utilisateur =====
 +
 +Il peut parfois être utile de rechercher les fichiers n'​appartenant pas à l'​utilisateur,​ en vue de corriger un problème rencontré avec une application (par exemple, un fichier peut appartenir à root au lieu d'​appartenir à l'​utilisateur ; ce dernier risque de ne pas avoir de droits dessus, ce que peut alors provoquer une erreur dans une application cherchant à modifier le dit fichier).
 +
 +Pour ce faire, il suffit d'​exécuter là commande suivante, où « utilisateur » est à remplacer par votre nom d'​utilisateur :
 +
 +<code user>
 +find /​home/​utilisateur ! -user utilisateur
 +</​code>​
 +
 +ou bien, en utilisant des variables :
 +
 +<code user>
 +find $HOME ! -user $USER
 +</​code>​
 +
 +Pour avoir davantage d'​informations sur les fichiers ainsi trouvés, vous pouvez ajouter l'​option ''​ls''​ :
 +
 +<code user>
 +find $HOME ! -user $USER -ls
 </​code>​ </​code>​
  
Ligne 167: Ligne 199:
 La commande **find** permet d'​effectuer toute sorte d'​action avec les fichiers trouvés. La commande **find** permet d'​effectuer toute sorte d'​action avec les fichiers trouvés.
  
-Une action très utile est "''​-exec''"​ qui permet d'​exécuter une commande sur les fichiers sélectionnés. +Une action très utile est "''​-exec''"​ qui permet d'​exécuter une commande sur les fichiers sélectionnés. ​\\
 La syntaxe de ''​exec''​ est particulière car il faut pouvoir fournir le nom du fichier trouvé. La syntaxe de ''​exec''​ est particulière car il faut pouvoir fournir le nom du fichier trouvé.
  
Ligne 180: Ligne 211:
  
 Par exemple ainsi : Par exemple ainsi :
-<​code ​bash>+<​code ​user>
 find /​home/​mon_user/​test/​ -type f -exec echo {} \+</​code>​ find /​home/​mon_user/​test/​ -type f -exec echo {} \+</​code>​
  
Ligne 193: Ligne 224:
  
 Voici par exemple comment on peut compter le nombre de lignes de chaque fichier de code Python de ce site: Voici par exemple comment on peut compter le nombre de lignes de chaque fichier de code Python de ce site:
-<​code ​bash>+<​code ​user>
    find developpement/​django/​certif -name '​*.py'​ -exec wc -l {} \;</​code>​    find developpement/​django/​certif -name '​*.py'​ -exec wc -l {} \;</​code>​
-<code>+<file bash résultat de la commande précédente
        1 developpement/​django/​certif/​__init__.py        1 developpement/​django/​certif/​__init__.py
        0 developpement/​django/​certif/​acronym/​__init__.py        0 developpement/​django/​certif/​acronym/​__init__.py
Ligne 202: Ligne 233:
       13 developpement/​django/​certif/​acronym/​urls.py       13 developpement/​django/​certif/​acronym/​urls.py
       42 developpement/​django/​certif/​acronym/​views.py       42 developpement/​django/​certif/​acronym/​views.py
-      .../​...</​code>+      .../​...</​file>
  
   - Ici la commande **find** est utilisée avec l'​option ''​-name''​ pour ne sélectionner que les fichiers se terminant par "''​.py''"​ (extension de Python).   - Ici la commande **find** est utilisée avec l'​option ''​-name''​ pour ne sélectionner que les fichiers se terminant par "''​.py''"​ (extension de Python).
Ligne 210: Ligne 241:
  
 Comme d'​habitude vous avez aussi le : Comme d'​habitude vous avez aussi le :
-<​code ​bash>+<​code ​user>
 man find</​code>​ man find</​code>​
  
Ligne 221: Ligne 252:
 Placez-vous dans un nouveau dossier créé pour l'​occasion. \\ Placez-vous dans un nouveau dossier créé pour l'​occasion. \\
 Exemple : Exemple :
-<​code ​bash>+<​code ​user>
 cd cd
 mkdir -p ~/​tmp/​df_tp01/​ mkdir -p ~/​tmp/​df_tp01/​
Ligne 229: Ligne 260:
 On va maintenant créer les fichiers et dossiers qui nous servirons pour la On va maintenant créer les fichiers et dossiers qui nous servirons pour la
 suite ainsi : suite ainsi :
-<​code ​bash>+<​code ​user>
 for i in $(seq 5); do mkdir toctoc$i; done for i in $(seq 5); do mkdir toctoc$i; done
 mkdir -p toctoc1/paf toctoc2/paf toctoc3/​pif/​paf toctoc4/​paf/​paf mkdir -p toctoc1/paf toctoc2/paf toctoc3/​pif/​paf toctoc4/​paf/​paf
Ligne 240: Ligne 271:
 À maîtriser absolument avant de poursuivre. À maîtriser absolument avant de poursuivre.
  
-  * [[manuel:repertoire ​| Différents types de chemin — Notion de répertoire de travail]] - Pas à pas. +  * [[:doc:​programmation:​shell:​repertoires ​| Différents types de chemin — Notion de répertoire de travail]] - Pas à pas.
- +
  
 ===== Find, -exec et -execdir ===== ===== Find, -exec et -execdir =====
Ligne 254: Ligne 283:
 Si vous lancez un ''​find''​ depuis le second répertoire de ce TP, vous allez voir ce sacré bazar : Si vous lancez un ''​find''​ depuis le second répertoire de ce TP, vous allez voir ce sacré bazar :
  
-<​code ​bash>+<​code ​user>
 ~/​tmp/​df_tp01$ find . ~/​tmp/​df_tp01$ find .
 </​code>​ </​code>​
  
 Par exemple, on va se concentrer sur les répertoires nommés ''​paf''​ : Par exemple, on va se concentrer sur les répertoires nommés ''​paf''​ :
-<​code ​bash+<​code ​user
-~/​tmp/​df_tp01$ find . -type d -name paf+~/​tmp/​df_tp01$ find . -type d -name paf</​code>​ 
 +<file bash résultat de la commande précédente> ​
 ./​toctoc3/​pif/​paf ./​toctoc3/​pif/​paf
 ./​toctoc1/​paf ./​toctoc1/​paf
Ligne 266: Ligne 296:
 ./​toctoc4/​paf/​paf ./​toctoc4/​paf/​paf
 ./​toctoc2/​paf ./​toctoc2/​paf
-</code>+</file>
  
 === Nota : === === Nota : ===
  
 Pour afficher les sous-dossiers en premier, on ajoute l'​option ''​-depth''​ **au début** de la commande Pour afficher les sous-dossiers en premier, on ajoute l'​option ''​-depth''​ **au début** de la commande
-<​code ​bash+<​code ​user
-~/​tmp/​df_tp01$ find . -depth -type d -name paf+~/​tmp/​df_tp01$ find . -depth -type d -name paf</​code>​ 
 +<file bash résultat de la commande précédente> ​
 ./​toctoc3/​pif/​paf ./​toctoc3/​pif/​paf
 ./​toctoc1/​paf ./​toctoc1/​paf
Ligne 278: Ligne 309:
 ./​toctoc4/​paf ./​toctoc4/​paf
 ./​toctoc2/​paf ./​toctoc2/​paf
-</code>+</file>
  
 ==== Répertoires de travail pour -exec et -execdir ==== ==== Répertoires de travail pour -exec et -execdir ====
Ligne 285: Ligne 316:
  
 Affichons le répertoire de travail : Affichons le répertoire de travail :
-<​code ​bash+<​code ​user
-~/​tmp/​df_tp01$ find . -depth -type d -name paf -exec pwd \;+~/​tmp/​df_tp01$ find . -depth -type d -name paf -exec pwd \;</​code>​ 
 +<file bash résultat de la commande précédente> ​
 /​home/​captnfab/​tmp/​df_tp01 /​home/​captnfab/​tmp/​df_tp01
 /​home/​captnfab/​tmp/​df_tp01 /​home/​captnfab/​tmp/​df_tp01
Ligne 292: Ligne 324:
 /​home/​captnfab/​tmp/​df_tp01 /​home/​captnfab/​tmp/​df_tp01
 /​home/​captnfab/​tmp/​df_tp01 /​home/​captnfab/​tmp/​df_tp01
-</code>+</file>
  
-On voit qu'​ici,​ pour chaque dossier ''​paf''​ de trouvé, c'est seulement __le chemin du répertoire d'où nous lançons notre commande find__, qui est indiqué par l'​exécution de [[commande:pwd | la commande : pwd]], ce qui n'est pas ce que nous voulons obtenir. 8-o+On voit qu'​ici,​ pour chaque dossier ''​paf''​ de trouvé, c'est seulement __le chemin du répertoire d'où nous lançons notre commande find__, qui est indiqué par l'​exécution de [[:​doc:​systeme:pwd | la commande : pwd]], ce qui n'est pas ce que nous voulons obtenir. 8-o
  
 Employons ''​-execdir''​ maintenant : Employons ''​-execdir''​ maintenant :
-<​code ​bash+<​code ​user
-~/​tmp/​df_tp01$ find . -depth -type d -name paf -execdir pwd \;+~/​tmp/​df_tp01$ find . -depth -type d -name paf -execdir pwd \;</​code>​ 
 +<file bash résultat de la commande précédente> ​
 /​home/​captnfab/​tmp/​df_tp01/​toctoc3/​pif /​home/​captnfab/​tmp/​df_tp01/​toctoc3/​pif
 /​home/​captnfab/​tmp/​df_tp01/​toctoc1 /​home/​captnfab/​tmp/​df_tp01/​toctoc1
Ligne 304: Ligne 337:
 /​home/​captnfab/​tmp/​df_tp01/​toctoc4 /​home/​captnfab/​tmp/​df_tp01/​toctoc4
 /​home/​captnfab/​tmp/​df_tp01/​toctoc2 /​home/​captnfab/​tmp/​df_tp01/​toctoc2
-</code>+</file>
  
 On voit maintenant que nous obtenons bien __le chemin de chaque répertoire contenant le dossier ''​paf''​__ qui est indiqué par l'​exécution de pwd, ce qui était recherché. :-D On voit maintenant que nous obtenons bien __le chemin de chaque répertoire contenant le dossier ''​paf''​__ qui est indiqué par l'​exécution de pwd, ce qui était recherché. :-D
Ligne 314: Ligne 347:
  
 C'est on ne peut plus simple : C'est on ne peut plus simple :
-<​code ​bash>+<​code ​user>
 ~/​tmp/​df_tp01$ find . -depth -type d -name paf -execdir mv paf ploum \; ~/​tmp/​df_tp01$ find . -depth -type d -name paf -execdir mv paf ploum \;
 </​code>​ </​code>​
  
 Vous pouvez vérifier que ça a bien marché avec la commande suivante : Vous pouvez vérifier que ça a bien marché avec la commande suivante :
-<​code ​bash>+<​code ​user>
 ~/​tmp/​df_tp01$ find . -depth -type d -name ploum ~/​tmp/​df_tp01$ find . -depth -type d -name ploum
 </​code>​ </​code>​
Ligne 328: Ligne 361:
 Site de ce matelot bienveillant d'où est totalement pompé cet exercice : Site de ce matelot bienveillant d'où est totalement pompé cet exercice :
   * http://​wiki.chezlefab.net/​tuto_nix/​tp/​find_01   * http://​wiki.chezlefab.net/​tuto_nix/​tp/​find_01
- 
  
 ===== Une seconde version plus scolaire du TP01 ===== ===== Une seconde version plus scolaire du TP01 =====
Ligne 335: Ligne 367:
  
 Placez-vous dans un nouveau dossier créé pour l'​occasion. Exemple : Placez-vous dans un nouveau dossier créé pour l'​occasion. Exemple :
-<​code ​bash>+<​code ​user>
 cd cd
 mkdir -p tmp/​df_tp01/​ mkdir -p tmp/​df_tp01/​
Ligne 345: Ligne 377:
  
 Voici pour la première partie : Voici pour la première partie :
-<​code ​bash>+<​code ​user>
 touch phaute_dorthografe touch phaute_dorthografe
 touch notes_temporaires touch notes_temporaires
Ligne 352: Ligne 384:
  
 Et pour la seconde : Et pour la seconde :
-<​code ​bash>+<​code ​user>
 ~/​tmp/​df_tp01$ for i in $(seq 5); do mkdir toctoc$i; done ~/​tmp/​df_tp01$ for i in $(seq 5); do mkdir toctoc$i; done
 ~/​tmp/​df_tp01$ mkdir -p toctoc1/paf toctoc2/paf toctoc3/​pif/​paf toctoc4/​paf/​paf ~/​tmp/​df_tp01$ mkdir -p toctoc1/paf toctoc2/paf toctoc3/​pif/​paf toctoc4/​paf/​paf
Ligne 366: Ligne 398:
 l'​afficher en tapant la commande ''​pwd''​. l'​afficher en tapant la commande ''​pwd''​.
  
-<​code ​bash+<​code ​user
-~/​tmp/​df_tp01$ pwd+~/​tmp/​df_tp01$ pwd</​code>​ 
 +<file bash résultat de la commande précédente> ​
 /​home/​captnfab/​tmp/​df_tp01 /​home/​captnfab/​tmp/​df_tp01
 ~/​tmp/​df_tp01$ ~/​tmp/​df_tp01$
-</code>+</file>
  
 On change de répertoire de travail avec la commande ''​cd''​. On change de répertoire de travail avec la commande ''​cd''​.
  
 Le répertoire de travail est également stocké dans la variable ''​$PWD''​ du shell. Le répertoire de travail est également stocké dans la variable ''​$PWD''​ du shell.
-<​code ​bash+<​code ​user
-~/​tmp/​df_tp01$ echo $PWD+~/​tmp/​df_tp01$ echo $PWD</​code>​ 
 +<file bash résultat de la commande précédente> ​
 /​home/​captnfab/​tmp/​df_tp01 /​home/​captnfab/​tmp/​df_tp01
 ~/​tmp/​df_tp01$ ~/​tmp/​df_tp01$
-</code>+</file>
  
 ==== Chemin relatif / chemin absolu ==== ==== Chemin relatif / chemin absolu ====
Ligne 421: Ligne 455:
 **Attention** : Virtuellement,​ un chemin relatif commence **toujours** par **Attention** : Virtuellement,​ un chemin relatif commence **toujours** par
 ''​./''​. Cependant, en règle générale, on peut l'​omettre. ​ Exemple ''​./''​. Cependant, en règle générale, on peut l'​omettre. ​ Exemple
-<​code ​bash>+<​code ​user>
 ls -lh quisuisje ls -lh quisuisje
 </​code>​ </​code>​
  
 Signifie en fait : Signifie en fait :
-<​code ​bash>+<​code ​user>
 ls -lh ./quisuisje ls -lh ./quisuisje
 </​code>​ </​code>​
Ligne 443: Ligne 477:
 Exemples : Exemples :
   * Avec deux chemins relatifs   * Avec deux chemins relatifs
-<​code ​bash>+<​code ​user>
 ~/​tmp/​df_tp01/​$ mv ./​phaute_dorthografe ./​faute_dorthographe ~/​tmp/​df_tp01/​$ mv ./​phaute_dorthografe ./​faute_dorthographe
 </​code>​ </​code>​
 qui signifie donc qui signifie donc
-<​code ​bash>+<​code ​user>
 mv $PWD/​./​phaute_dorthografe $PWD/​./​faute_dorthographe mv $PWD/​./​phaute_dorthografe $PWD/​./​faute_dorthographe
 </​code>​ </​code>​
  
   * Avec un chemin relatif et un chemin absolu   * Avec un chemin relatif et un chemin absolu
-<​code ​bash>+<​code ​user>
 ~/​tmp/​df_tp01/​$ mv ./​notes_temporaires /​tmp/​notes_temporaires.txt ~/​tmp/​df_tp01/​$ mv ./​notes_temporaires /​tmp/​notes_temporaires.txt
 </​code>​ </​code>​
 qui signifie qui signifie
-<​code ​bash>+<​code ​user>
 ~/​tmp/​df_tp01/​$ mv $PWD/​./​notes_temporaires /​tmp/​notes_temporaires.txt ~/​tmp/​df_tp01/​$ mv $PWD/​./​notes_temporaires /​tmp/​notes_temporaires.txt
 </​code>​ </​code>​
Ligne 471: Ligne 505:
 Si vous lancez un ''​find''​ depuis le répertoire du tp, vous allez voir un sacré bazar : Si vous lancez un ''​find''​ depuis le répertoire du tp, vous allez voir un sacré bazar :
  
-<​code ​bash>+<​code ​user>
 find . find .
 </​code>​ </​code>​
  
 On va se concentrer sur les répertoires ''​paf''​ : On va se concentrer sur les répertoires ''​paf''​ :
-<​code ​bash>+<​code ​user>
 find . -type d -name paf</​code>​ find . -type d -name paf</​code>​
-<code>+<file bash résultat de la commande précédente
 ./​toctoc3/​pif/​paf ./​toctoc3/​pif/​paf
 ./​toctoc1/​paf ./​toctoc1/​paf
Ligne 484: Ligne 518:
 ./​toctoc4/​paf/​paf ./​toctoc4/​paf/​paf
 ./​toctoc2/​paf ./​toctoc2/​paf
-</code>+</file>
  
 Pour afficher les sous-dossiers en premier, on ajoute l'​option ''​-depth''​ **au début** de la commande Pour afficher les sous-dossiers en premier, on ajoute l'​option ''​-depth''​ **au début** de la commande
-<​code ​bash>+<​code ​user>
 find . -depth -type d -name paf</​code>​ find . -depth -type d -name paf</​code>​
-<code>+<file bash résultat de la commande précédente
 ./​toctoc3/​pif/​paf ./​toctoc3/​pif/​paf
 ./​toctoc1/​paf ./​toctoc1/​paf
Ligne 495: Ligne 529:
 ./​toctoc4/​paf ./​toctoc4/​paf
 ./​toctoc2/​paf ./​toctoc2/​paf
-</code>+</file>
  
 ==== Répertoires de travail pour -exec et -execdir ==== ==== Répertoires de travail pour -exec et -execdir ====
Ligne 502: Ligne 536:
 répertoire de travail. répertoire de travail.
  
-<​code ​bash>+<​code ​user>
 find . -depth -type d -name paf -exec pwd \;</​code>​ find . -depth -type d -name paf -exec pwd \;</​code>​
-<code>+<file bash résultat de la commande précédente
 /​home/​captnfab/​tmp/​df_tp01 /​home/​captnfab/​tmp/​df_tp01
 /​home/​captnfab/​tmp/​df_tp01 /​home/​captnfab/​tmp/​df_tp01
Ligne 510: Ligne 544:
 /​home/​captnfab/​tmp/​df_tp01 /​home/​captnfab/​tmp/​df_tp01
 /​home/​captnfab/​tmp/​df_tp01 /​home/​captnfab/​tmp/​df_tp01
-</code>+</file>
  
 Comparons avec ''​-execdir''​ Comparons avec ''​-execdir''​
Ligne 516: Ligne 550:
 <code bash> <code bash>
 find . -depth -type d -name paf -execdir pwd \;</​code>​ find . -depth -type d -name paf -execdir pwd \;</​code>​
-<code>+<file bash résultat de la commande précédente
 /​home/​captnfab/​tmp/​df_tp01/​toctoc3/​pif /​home/​captnfab/​tmp/​df_tp01/​toctoc3/​pif
 /​home/​captnfab/​tmp/​df_tp01/​toctoc1 /​home/​captnfab/​tmp/​df_tp01/​toctoc1
Ligne 522: Ligne 556:
 /​home/​captnfab/​tmp/​df_tp01/​toctoc4 /​home/​captnfab/​tmp/​df_tp01/​toctoc4
 /​home/​captnfab/​tmp/​df_tp01/​toctoc2 /​home/​captnfab/​tmp/​df_tp01/​toctoc2
-</code>+</file>
  
 On voit ici que le répertoire de travail est à chaque fois le répertoire contenant le dossier ''​pif''​. On voit ici que le répertoire de travail est à chaque fois le répertoire contenant le dossier ''​pif''​.
Ligne 532: Ligne 566:
 C'est on ne peut plus simple : C'est on ne peut plus simple :
  
-<​code ​bash>+<​code ​user>
 find . -depth -type d -name paf -execdir mv paf ploum  \; find . -depth -type d -name paf -execdir mv paf ploum  \;
 </​code>​ </​code>​
Ligne 538: Ligne 572:
 Vous pouvez vérifier que ça a bien marché avec la commande suivante : Vous pouvez vérifier que ça a bien marché avec la commande suivante :
  
-<​code ​bash>+<​code ​user>
 find . -depth -type d -name ploum find . -depth -type d -name ploum
 </​code>​ </​code>​
Ligne 550: Ligne 584:
  
 On se place à la racine du répertoire cible : On se place à la racine du répertoire cible :
-<​code ​bash>+<​code ​user>
 cd /​repertoire/​machin</​code>​ cd /​repertoire/​machin</​code>​
  
 et on tape : et on tape :
-<​code ​bash>+<​code ​user>
 find . -depth -type f -exec sed -i '​s/​require(/​@require_once(/​g'​ {} \;</​code>​ find . -depth -type f -exec sed -i '​s/​require(/​@require_once(/​g'​ {} \;</​code>​
  
Ligne 567: Ligne 601:
 === le chevron === === le chevron ===
  
-Avec [[commande:chevron|la commande chevron]] +Avec [[:doc:​programmation:​shell:​chevrons|la commande chevron]] 
-<​code ​bash>+<​code ​user>
 find -type f -iname nom_du_fichier -execdir cat {} nom_du_fichier + > nom_du_fichier \;</​code>​ find -type f -iname nom_du_fichier -execdir cat {} nom_du_fichier + > nom_du_fichier \;</​code>​
  
Ligne 574: Ligne 608:
  
 Ou bien avec **xargs** : Ou bien avec **xargs** :
-<​code ​bash>+<​code ​user>
 find -type f -iname nom_du_fichier | xargs cat > nom_du_fichier \;</​code>​ find -type f -iname nom_du_fichier | xargs cat > nom_du_fichier \;</​code>​
  
 === cp === === cp ===
  
-Ou encore avec [[commande:cp|la commande cp]] : +Ou encore avec [[:​doc:​systeme:cp|la commande cp]] : 
-<​code ​bash>+<​code ​user>
 find -type f -iname nom_du_fichier -exec cp /dev/null {} \;</​code>​ find -type f -iname nom_du_fichier -exec cp /dev/null {} \;</​code>​
  
doc/systeme/find.txt · Dernière modification: 24/10/2022 18:38 par Jean-Pierre Pinson

Pied de page des forums

Propulsé par FluxBB