Dans l’exemple ci-dessus, le mot evry est recherché dans le fichier /etc/hosts. Si grep ne renvoie aucun résultat alors le mot evry n’a pas été trouvé dans le fichier, sinon grep affiche les lignes du fichier contenant ce mot.
Pour rechercher le mot alias dans tous les fichiers commençant par « . », il faut exécuter:
grep affiche alors le nom du fichier dans lequel le mot alias a été trouvé puis la ou les lignes contenant ce mot.
Pour afficher les lignes ne contenant pas une certaine expression, il faut utiliser l’option -v. Il existe beaucoup d’autres options: -n pour affichage des numéros de lignes, -l pour afficher le nom des fichiers dans lesquels l’expression est trouvée, -i pour indifférencier les majuscules des minuscules...
Il est parfois utile d’extraire d’un fichier une partie seulement des informations de chaque ligne. La commande cut permet d’afficher une portion de chaque ligne des fichiers passés en arguments ou à défaut de l’entrée standard. La portion sélectionnée peut être définie en termes de caractères (option -c) ou en termes de champs (-f) et parfois en termes d’octets (option -b). Il faut obligatoirement utiliser l’une de ces options suivie d’une liste d’entiers séparés par des virgules. Le séparateur de champ par défaut est le caractère tabulation qui peut être remplacé par le caractère x avec l’option -dx (et non -tx comme nous verrons pour sort).
Les deux exemples suivants sont des utilisations simples de cut. Pour afficher le deuxième champ de chaque ligne du fichier fich avec une tabulation comme séparateur, il faut écrire:
Pour modifier le séparateur, il faut utiliser l’option -d. Ainsi pour que le séparateur soit un espace et non une tabulation, il faut écrire:
Pour afficher le troisième caractère de chaque ligne du fichier fich, il faut écrire:
Nous ajoutons deux exemples plus complexes d’utilisation de cut. Vous avez vu, à la section 4 la commande who permettant de savoir qui est connecté à un moment donné. Cette commande affiche une ligne par utilisateur connecté. Sur chaque ligne, les huit premiers caractères correspondent au nom de connexion. Le premier exemple récupère uniquement le nom de connexion de tous les utilisateurs connectés à un moment donné. Le résultat de who est passé à cut qui sélectionne les huit premiers caractères avec l’option -c1-8.
Le second exemple analyse le fichier /etc/passwd. Le fichier /etc/passwd contient une ligne par utilisateur autorisé à se connecter au système. Chaque ligne contient le nom de l’utilisateur et un certain nombre d’informations. Chacun de ces champs est séparé du précédent par :. La commande suivante récupère le nom des utilisateurs. Pour afficher les noms des utilisateurs contenus dans le fichier /etc/passwd, cut redéfinit le séparateur de champs avec l’option -d pour que le séparateur soit le caractère :, puis affiche le premier champ avec l’option -f1.