====== LOCATE - Commande de Recherche ======
* Objet : retrouver des fichiers avec la commande locate
* Niveau requis : {{tag>débutant avisé}}
* Commentaires : //La recherche de fichiers rapide//
* Débutant, à savoir : [[:doc:systeme:commandes:le_debianiste_qui_papillonne|Utiliser GNU/Linux en ligne de commande, tout commence là !]] :-)
* Suivi :
* Création par [[user>MaTTux]] juin 2012
* Testé par [[user>Hypathie]] le 10/08/2014
* Commentaires sur le forum : [[https://debian-facile.org/viewtopic.php?pid=96486#p96486| c'est ici.]] ((N'hésitez pas à y faire part de vos remarques, succès, améliorations ou échecs !))
===== Introduction =====
==== Comment la commande locate fonctionne-t-elle ? ====
''locate'' renvoie __le cheminement complet__ du sujet de votre recherche.
La commande ''locate'' effectue une recherche de fichiers et répertoires de manière extrêmement rapide grâce à une base de donnée.
Par défaut, cette base de données est mise à jour toutes les 24h ce qui est suffisant pour son usage général. En cas de besoin on actualise la base de données manuellement, ce qui prend de quelques secondes à quelques minutes selon la taille du système de fichiers concerné.
Bien que la commande ''locate'' soit moins élaborée que la commandes [[:doc:systeme:find]] et inadaptée aux fichiers changeants, sa vitesse et sa facilité d'emploi en fait une commande redoutablement efficace, tant pour des recherches simples que pour celles qui portent sur la totalité du système de fichiers. Vous ne vous poserez plus jamais la question de savoir où est planqué ce fichu fichier php.ini
''locate'' est donc très complémentaire à la commande [[:doc:systeme:find]] qui elle est plus adaptée aux recherches locales et complexes, notamment avec des traitements sur les résultats comme avec la classique commande [[GREP]] ou en utilisant l'option -exec
==== Mise à jour de la base de données ====
:-) **locate** effectue cette recherche dans une base de données rafraîchie automatiquement toutes les 24 h !
:-( Cela signifie aussi que **locate** ne peut être lancée sur un travail de moins de 24 h !
:-D Mais !... Mais, mais, mais... Il est possible de réactualiser cette bd (base de données) par la commande :
updatedb
Cette mise à jour prend plus ou moins de temps, selon les nouveautés que vous avez réalisées dernièrement sur votre pc.
La commande ''locate'' permet de visualiser tous les fichiers en tant que simple utilisateur.\\
Cela est dû au fait qu'en lançant ''locate'', nous utilisons maintenant l'application ''mlocate'' qui évite tous les messages d'erreurs qui pourraient survenir du fait de la limitation de droits. \\
==== Retrouver le chemin de "mlocate" ====
La commande locate est un lien symbolique vers ''mlocate''. Pour le vérifier, on peut utiliser la commande ls((avec la commande ls, on obtient "lrwxrwxrwx" où la première lettre symbolise le type de fichier)).\\
Par exemple sur ma lenny :
* Tout d'abord, pour connaître le chemin complet de la commande :
type locate
locate est /usr/bin/locate
* Puis avec la commande ls :
ls -l /usr/bin/locate
lrwxrwxrwx 1 root root 24 avr 17 13:06 /usr/bin/locate -> /etc/alternatives/locate
> Où la première lettre "l" (la lettre L minuscule), signifie qu'il s'agit d'un lien symbolique.
* Puis on fait la même chose pour l'utilitaire lié à locate :
ls -l /etc/alternatives/locate
lrwxrwxrwx 1 root root 16 avr 17 13:06 /etc/alternatives/locate -> /usr/bin/mlocate
Connaître le chemin, c'est-à-dire aussi le nom complet d'une commande, permet parfois d'éviter bien des tracas, lorsqu'on veut utiliser cette commande dans un script shell.\\
Il vous est maintenant possible, pour effectuer une recherche, d'utiliser :
-soit ''locate critère-de-recherche''
-soit ''/etc/alternatives/locate critère-de-recherche''
-soit enfin ''/usr/bin/mlocate critère-de-recherche''
===== TP 01 Exemple d'utilisation de locate =====
Je recherche des fichiers .jpg que j'ai renommé avec un w afin de les désigner comme susceptibles de paraître sur le web. \\
Mais où donc les ai-je disposées ? \\
''locate'' //est là, et le doute s'en va !// ;-)
Ainsi :
locate '*w.jpg'
/home/mon-user/2010-04-16--23.00.39/002w.jpg
/home/mon-user/2010-04-16--23.00.39/005w.jpg
/home/mon-user/2010-04-16--23.00.39/016w.jpg
/home/mon-user/2010-04-16--23.00.39/018w.jpg
.../...
Résultat fulgurant et magique ! :-D
=====Locate - la syntaxe, les options =====
===Syntaxe===
locate
===Les options===
^ //OPTIONS// ^ //ACTION// ^
| **-i** | pour ignorer la casse majuscule ou minuscule |
| **-c** | afficher seulement le nombre de résultat |
| **-u** | crée une base de données à partir de la racine ''/'' |
| **-U** | ajoute dans la base de données le répertoire spécifié. |
| **-r** | effectue la recherche du nom dans la base de données |
| **-o** | spécifie la création d'une base de données ( database). |
| **-d** | le chemin de la base de données : ''locate -d '' |
| **-e** | - exclusion des répertoires de la database lors de l'utilisation des options -U ou u |
| **-l** | - Niveau de sécurité |
| **-n ** | N'affiche que les n premiers résultats |
| **-0** | Séparer les entrées sur la sortie à l'aide du caractère ASCII NUL au lieu d'écrire chaque entrée sur une ligne distincte. Cette option est conçue pour l'interopérabilité avec l'option --null de xargs GNU (1) |
==== Exemples ====
=== Option : -i ===
Pour ignorer les Majuscules ou minuscules :
locate -i '*W.jpg'
/home/mon_user/2010-04-16--23.00.39/002w.jpg
/home/mon_user/2010-04-16--23.00.39/005w.jpg
/home/mon_user/2010-04-16--23.00.39/016w.jpg
/home/mon_user/2010-04-16--23.00.39/018w.jpg
/home/mon_user/2010-04-18--17.36.56/003w.jpg
.../...
Notez l'emploi des quotes '' pour signaler au shell qu'il s'agit d'une chaine de caractère.
=== Option -n ===
Pour afficher les 2 premiers résultats contenant "net" dans le dossier des configurations /etc :
locate -n 2 '/etc*net*'
=== Option -c ===
Pour comptabiliser les fichiers trouvés :
locate -c '*w.jpg'
15
=== Option -r ===
locate -r
>L'option -r va créer récursivement le contenu de tous les sous-répertoires et fichiers se trouvant dans le répertoire indiqué.
>Le contenu ( liste) sera stocké à la suite du fichier slocate.db ( la database ), qui se trouve dans le répertoire :
/var/lib/slocate/slocate.db
===== TP 02 Créer un fichier de recherche =====
Chercher un fichier contenant la chaîne "mime", tu retrouveras le fichier de recherche dans "/tmp"((Voir: [[:doc:programmation:shell:chevrons]])).
locate mime > /tmp/recherche-mime.txt
===== Source : =====
**Sorcier_FXK**, **captnfab** et **MaTTux_** sur le chan DF, //que leur sciences soient bénies et révérées à jamais// \\
Et un livre bien utile :
* **Scott Granneman** - Le Guide de Survie - //L'essentiel du code et des commandes Linux//
**Lætitia** & **Bagatore** sur le forum ici :
* http://debian-facile.org/forum/viewtopic.php?pid=48706#p48706
//Comme quoi le carambar et les tagadas, ça en met dans la cervelle !// ;-)