Maison > Article > Opération et maintenance > Puis-je trouver le contenu d’un fichier sous Linux ?
Sous Linux, vous pouvez utiliser la commande grep pour rechercher le contenu d'un fichier. Cette commande est un puissant outil de recherche de texte utilisé pour rechercher des chaînes qualifiées dans les fichiers. Les expressions régulières peuvent être utilisées pour rechercher du texte ; ".
L'environnement d'exploitation de ce tutoriel : système linux5.9.8, ordinateur Dell G3.
Sous Linux, vous pouvez utiliser la commande grep pour rechercher le contenu d'un fichier.
La commande grep (Global Regular Expression Print) du système Linux est un puissant outil de recherche de texte, utilisé pour rechercher des chaînes qualifiées dans des fichiers. Elle peut utiliser des expressions régulières pour rechercher du texte et imprimer les lignes correspondantes.
L'origine de la commande grep remonte aux débuts d'UNIX. Dans les systèmes UNIX, les modèles de recherche sont appelés expressions régulières. Afin de rechercher de manière approfondie un fichier, certains utilisateurs recherchent La chaîne est préfixée par global (. complet). Une fois le contenu correspondant trouvé, l'utilisateur l'imprimera à l'écran. L'intégration de cette série d'opérations est l'impression d'expressions régulières globales, et c'est le nom complet de la commande grep.
La commande grep peut rechercher un modèle de caractère spécifique (expression régulière) dans un ou plusieurs fichiers. Ce modèle peut être un seul caractère, une chaîne, un mot ou une phrase.
Une expression régulière est un modèle qui décrit un ensemble de chaînes. La composition d'une expression régulière imite une expression mathématique, en utilisant des opérateurs pour combiner des expressions plus petites en une nouvelle expression. Les expressions régulières peuvent être du texte brut ou des caractères spéciaux utilisés pour générer des modèles. Pour définir davantage un modèle de recherche, la commande grep prend en charge les métacaractères (également appelés caractères génériques) pour les expressions régulières, comme indiqué dans le tableau 1.
Wildcard | fonction |
---|---|
c* | correspondra à 0 (c'est-à-dire vide) ou plus de caractères c (c est n'importe quel caractère). |
. | correspondra à n'importe quel caractère et ne peut être qu'un seul caractère. |
[xyz] | correspond à n'importe quel caractère entre crochets. |
[^xyz] | correspond à tous les caractères sauf les caractères entre crochets. |
^ | Verrouillez le début de la ligne. |
$ | Verrouillez le bout de la ligne. |
Il est à noter que dans les expressions régulières de base, telles que les caractères génériques *, +, {, |, ( et ), etc., ils ont perdu leur sens originel pour restaurer leur sens originel, puis Être. précédé d'une barre oblique inverse, telle que *, +, {, |, ( et ).
La commande grep est utilisée pour rechercher un modèle spécifique dans chaque fichier ou support (ou sur une sortie spécifique). Lors de l'utilisation de grep, chaque ligne contenant le modèle de caractère spécifié sera imprimée (affichée) à l'écran, mais en utilisant The. La commande grep ne modifie pas le contenu du fichier.
Le format de base de la commande grep est le suivant :
[root@localhost ~]# grep [选项] 模式 文件名
Le modèle ici est soit un caractère (chaîne) soit une expression régulière. Les options couramment utilisées de cette commande et leurs significations respectives sont présentées dans le tableau 2.
Option | Signification |
---|---|
-c | Répertoriez uniquement le nombre de lignes contenant le motif dans le fichier. |
-i | Ignorez la casse des lettres dans les motifs. |
-l | Liste les noms de fichiers avec les lignes correspondantes. |
-n | Inscrivez le numéro de ligne au début de chaque ligne. |
-v | Liste les lignes sans motif correspondant. |
-w | Recherchez l'expression comme un caractère unique complet, en ignorant les lignes qui correspondent partiellement. |
Notez que si vous recherchez plusieurs fichiers, les résultats de la commande grep n'afficheront que les noms de fichiers dans les fichiers qui correspondent au modèle ; si vous recherchez un seul fichier, les résultats de la commande grep s'afficheront tous les deux ; ligne qui contient le motif correspondant.
[Exemple 1] Supposons qu'il y ait une liste d'employés dans emp.data. Vous souhaitez maintenant rechercher dans ce fichier tous les employés ayant le poste CLERK. Exécutez ensuite la commande comme suit :
[root@localhost ~]# grep CLERK emp.data #忽略输出内容
Sur cette base, si vous. je veux seulement connaître les employés dont le poste est CLERK Pour le nombre d'employés CLERK, vous pouvez utiliser l'option "-c" La commande d'exécution est la suivante :
[root@localhost ~]# grep -c CLERK emp.data #忽略输出内容
[Exemple 2] Recherchez le fichier emp.data et utilisez Regular. expressions pour trouver les lignes de données commençant par 78. La commande d'exécution est la suivante :
[root@localhost ~]# grep ^78 emp.data #忽略输出内容
La commande grep est très puissante En utilisant ses différentes options et ses expressions régulières en constante évolution, nous pouvons obtenir toutes les informations dont nous avons besoin.
Recommandations associées : "Tutoriel vidéo Linux"
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!