grep

Comment utiliser des caractères spéciaux dans la commande Grep?

Comment utiliser des caractères spéciaux dans la commande Grep?

La fonction de grep est de rechercher le texte et de lui appliquer des conditions. Il est utilisé pour rechercher dans plus d'un fichier. Grep peut identifier les lignes de texte qu'il contient et décider en outre d'appliquer différentes actions qui incluent la fonction récursive ou inverser la recherche et afficher le numéro de ligne en sortie, etc. Les caractères spéciaux sont les expressions régulières utilisées dans les commandes pour effectuer plusieurs actions comme #, %, *, &, $, @, etc. Dans cet article, nous utiliserons des caractères spéciaux. Grep autorise les arguments sous forme de chaînes spécifiées en tant qu'expression régulière. Il a également la capacité de remplacer un mot ou une phrase dans celui-ci. Les caractères spéciaux ne sont pas seulement utilisés comme nom de fichier mais aussi comme données présentes à l'intérieur du fichier.

Prérequis

Pour l'exécuter, nous devons avoir le système d'exploitation Linux. Pour que Linux fonctionne, nous devons avoir une boîte virtuelle pré-installée.  Après l'installation réussie de Linux, vous allez le configurer en fournissant quelques informations utiles. La prochaine étape consiste à entrer dans la page d'accueil d'Ubuntu Linux. En fournissant le nom d'utilisateur et le mot de passe, vous pourrez accéder à toutes les applications -typectrl+alt+t pour ouvrir le terminal.

Utilisation de « $ »

Pour comprendre le concept du caractère spécial "$" dans la commande grep, vous devez avoir un fichier nommé file21.SMS. "$" est utilisé pour afficher toutes les lignes ayant un caractère défini derrière le "$" qui est un point-virgule, i.e., ';$'. Nous pouvons afficher tout le contenu pertinent en utilisant la commande cat.

$ Fichier de chat21.SMS

Maintenant, nous allons utiliser le caractère dans la commande suivante pour comprendre comment cela fonctionne. "-e" permet d'afficher la correspondance exacte dans le fichier.

$ grep -e ';$' fichier21.SMS

La sortie ci-dessus montre toutes les lignes du fichier ayant un point-virgule « ; » à la fin. Le résultat respectif est mis en évidence contre chaque ligne.

Utilisant"

Ceci est un exemple simple d'une expression régulière. Dans toute instruction grep, les guillemets simples sont utilisés lorsque nous voulons faire correspondre n'importe quel mot à l'intérieur d'un fichier. De même, nous avons évoqué cet exemple pour le rendre précis et bien compréhensible pour l'utilisateur.

$ grep -e 'Aqsa' fichier23.SMS

La sortie contiendra toutes les phrases contenant le mot Aqsa puisque nous avons recherché ce mot dans la commande.

Utilisant []

Les crochets sont utilisés pour mentionner le mot à rechercher entre les deux paires de crochets. Ces crochets sont suivis du « * » dans la commande. De plus, nous avons utilisé -n -I -w -e dans la commande pour obtenir la sortie avec le numéro de ligne avec précision, en ignorant la sensibilité à la casse, et obtenir la correspondance précise qui s'est produite plus d'une fois dans un fichier. Nous allons utiliser un fichier fileg.txt pour afficher les données qu'il contient. -E est utilisé comme expression régulière étendue chaque fois que nous utilisons un caractère dans la commande.

$ Filet de chat.SMS

Nous allons maintenant appliquer la requête suivante.

$ grep -noiwe -e '[]*le[]*' fichierg.SMS

Où fileg.txt est un fichier concerné. La sortie affiche le mot « le » partout où il est présent dans le fichier avec le numéro de ligne. Seul le mot est affiché mais pas la phrase entière car nous avons utilisé -w et -e pour afficher son occurrence et montrer la précision.

Utilisant '-'

'-' est utilisé dans la commande pour trouver une correspondance dans le fichier. -niw représente à nouveau la même signification que celle décrite dans l'exemple mentionné ci-dessus. -m affiche la première ligne contenant le mot dans le fichier existant.

$ grep -niw -m 3 fichier 'technique'1.SMS

La sortie affiche les lignes contenant le mot technique. Le numéro de ligne qui a le mot 'technique' est également affiché qui est en 1 et 4.

Utilisation de « | »

Ce caractère spécial est utilisé de plusieurs manières. En général, il est utilisé comme opérateur OU pour faire une option entre les deux prénoms. Dans une commande grep, il est utilisé pour opérer de sorte qu'il récupère l'enregistrement d'un ou des deux mots séparés par " | ". Ici, l'exemple montre la récupération de deux mots présents dans tous les fichiers du répertoire.

$ grep -I -E -w 'Aqsa|good' /home/aqsayasin/file*

Maintenant, la sortie montre les deux mots présents soit dans un seul fichier, soit dans des fichiers différents. Comme nous l'avons mentionné dans le répertoire, nous obtiendrons également les noms de fichiers.

Utilisation de '^()'

Ici '^()' agit de manière récursive par rapport à l'exemple ci-dessus."^" ne montre qu'une des deux options données, je.e., Aqsa et bon, ça vient en premier dans n'importe quel dossier. La sortie contiendra uniquement Aqsa. Egrep est une expression régulière étendue.

$ egrep -I '^(aqsa|bon)' /home/aqsayasin/*.SMS

Utilisation de ^$

Il montre la correspondance des chaînes vides/vides à la fin d'une ligne. Si un écart est présent dans le texte, il est récupéré par la commande suivante.

$ grep -n '^$' /home/aqsayasin/*.SMS

Tous les fichiers texte seront recherchés. La sortie contiendra les noms de fichiers ainsi que le numéro de ligne qui contient l'espace vide dans le fichier. Nous avons utilisé -n dans la commande.

Utilisant []

Ces deux parenthèses montrent comment fonctionnent les caractères spéciaux. [] contient le mot à rechercher. En même temps, décrit la correspondance dans le fichier N fois. Dans l'exemple précédent, nous avons utilisé 2, qui montre l'occurrence des deux mots possibles du mot fourni dans la commande qui est « le ».

$ egrep '[le]2' /home/aqsayasin/file*

Conclusion

Dans l'article mentionné précédemment, nous avons discuté de quelques exemples de base pour expliquer le concept de caractères spéciaux dans une commande. Nous avons créé le fichier puis récupéré les données qu'il contient en utilisant la commande grep. J'espère qu'après avoir lu cet article, vous serez familiarisé avec les caractères spéciaux que nous avons utilisés dans notre article.

Comment installer League Of Legends sur Ubuntu 14.04
Si vous êtes fan de League of Legends, alors c'est l'occasion pour vous de tester League of Legends. Notez que LOL est pris en charge sur PlayOnLinux ...
Installez le dernier jeu de stratégie OpenRA sur Ubuntu Linux
OpenRA est un moteur de jeu de stratégie en temps réel libre/gratuit qui recrée les premiers jeux Westwood comme le classique Command & Conquer: Red A...
Installez le dernier émulateur Dolphin pour Gamecube et Wii sur Linux
L'émulateur Dolphin vous permet de jouer aux jeux Gamecube et Wii de votre choix sur des ordinateurs personnels Linux (PC). Étant un émulateur de jeu...