Maison > Article > Opération et maintenance > Explication détaillée des cas de code sur grep et les expressions régulières sous Linux
Grep est un puissant outil de recherche de texte qui peut utiliser des expressions régulières pour rechercher du texte et imprimer les lignes correspondantes. Il existe généralement trois versions de grep : grep, egrep (équivalent à grep -E) et fgrep. egrep est un grep étendu et fgrep est un grep rapide (chaîne fixe pour rechercher du texte, ne prend pas en charge les références d'expressions régulières mais la requête est extrêmement rapide). grep est l'un des trois mousquetaires du traitement de texte Linux.
Comment utiliser : grep [OPTIONS] PATTERN [FILE...]
grep [OPTIONS] [-e PATTERN | [FILE ...]
Options communes :
--color=auto : Colorez le texte correspondant et mettez-le en surbrillance
-i : Ignorer la taille des caractères ; Écrivez
-o : affiche uniquement les chaînes correspondantes
-v : affiche les lignes qui ne peuvent pas correspondre au modèle
-E : prend en charge l'utilisation d'expressions régulières étendues
-q : Mode silencieux, c'est-à-dire qu'aucune information n'est émise
-A # : Afficher les lignes correspondant au motif et # lignes après celui-ci
-B # : Afficher les lignes correspondant au motif Lignes correspondant au motif et les # lignes avant et après
-C # : Afficher les lignes correspondant au motif et les # lignes avant et après
Remarque : obligatoire lors de l'utilisation de la correspondance grep. Utilisez des guillemets doubles (les guillemets simples sont des guillemets forts) pour éviter que le système ne les confonde avec des paramètres ou des commandes spéciales et ne signale une erreur.
Utilisation : egrep [OPTIONS] PATTERN [FILE...]
grep -E [OPTIONS] ] PATTERN [FILE...]
-i : ignorer la casse des caractères
-o : afficher uniquement la chaîne correspondante elle-même
-v : afficher le motif ne correspondant pas au ligne
-q : mode silencieux, c'est-à-dire qu'aucune information n'est émise
-A # : Afficher la ligne correspondant au motif et les # lignes qui le suivent
-B # : Afficher la ligne correspondant au motif motif et ses # lignes # précédentes
-C # : affiche les lignes correspondant au motif et les # lignes avant et après
-G : prend en charge les expressions régulières de base
'^' : Ancre le début de la ligne
'$' : Ancre la fin de la ligne
'.' : Correspond à n'importe quel caractère
' *' : correspond à zéro ou plusieurs caractères précédents
'?' : correspond au caractère précédent 0 ou 1 fois
'+' : correspond au caractère précédent 1 ou plusieurs fois
;'{m}' : fait correspondre le caractère qui le précède m fois (pour les caractères d'échappement)
'{m,n}' : fait correspondre le caractère qui le précède au moins m fois et au plus n fois
[]' : correspond à un caractère dans la plage spécifiée | '[^]' correspond à n'importe quel caractère en dehors de la plage spécifiée
'0c51fe397a0c661a6410171878109a6a' ou 'b' : fin du mot d'ancrage (disponible cd22d989ebecf0466bc673f30afdaf24 : correspond à des mots complets)
()' : traite plusieurs caractères dans leur ensemble
Référence arrière : Référencez les caractères correspondant au motif dans les parenthèses de regroupement précédentes
Le contenu correspondant au motif dans les parenthèses de regroupement peut être automatiquement enregistré par le moteur d'expression régulière Dans les variables internes :
1 : Le motif commence par la gauche, le contenu correspond au motif entre la première parenthèse gauche et la parenthèse droite correspondante
2 : Le Le motif commence à gauche, le contenu correspond au motif entre le deuxième crochet gauche et le crochet droit correspondant...
Les expressions régulières étendues sont légèrement différentes des expressions régulières :
[]' : correspond toujours à n'importe quel caractère dans la plage spécifiée mais il existe de nombreuses méthodes de correspondance spéciales ;
[:digit:] correspond à n'importe quel chiffre
[:lower:] correspond à n'importe quelle lettre minuscule
[:upper:] correspond à n'importe quelle majuscule lettre [:alpha:] correspond à n'importe quelle lettre [:alnum:] correspond à n'importe quelle lettre ou chiffre [:punct:] correspond à n'importe quel symbole [:space:] correspond à un seul espace Certains endroits annulent l'utilisation des caractères d'échappement : '?' : correspond au caractère précédent 0 ou 1 fois ;'+' : Faites correspondre le caractère qui le précède 1 ou plusieurs fois '{m}' : Faites correspondre le caractère qui le précède m fois (pour les caractères d'échappement)
'{m ,n}' : Faites correspondre le caractère précédent au moins m fois et au plus n fois () : Regroupez un ou plusieurs caractères ensemble et traitez-les dans leur ensemble, les références inversées sont utilisées comme d'habitude. |' : ou (
Remarque : 'C|cat' signifie C et chat, '(C|c)at est Chat et chat')
Questions pratiques : 1. Répertoriez les noms d'utilisateur de tous les utilisateurs connectés sur le système actuel Remarque : Si le même utilisateur se connecte plusieurs fois, il ne sera affiché qu'une seule fois<.>
[root@localhost ~]# who | cut -d' ' -f1|uniqroot
[root@localhost ~]# id `last | head -1 | cut -d' ' -f1` uid=0(root) gid=0(root) groups=0(root)
[root@localhost ~]# cut -d':' -f7 /etc/passwd|uniq -c|sort -n|tail -1|cut -d' ' -f7/sbin/nologin
4.将/etc/passd中的第三个字段设置最大的后10个用户的信息全部改为大写保存至/tmp/maxuser.txt文件中
[root@localhost ~]# sort -t':' -k3 -n /etc/passwd|tail -10|tr 'a-z' 'A-Z' >/tmp/maxusers.txt [root@localhost ~]# cat /tmp/maxusers.txt NOBODY:X:99:99:NOBODY:/:/SBIN/NOLOGIN SYSTEMD-NETWORK:X:192:192:SYSTEMD NETWORK MANAGEMENT:/:/SBIN/NOLOGIN NGINX:X:996:994:NGINX WEB SERVER:/VAR/LIB/NGINX:/SBIN/NOLOGIN CHRONY:X:997:995::/VAR/LIB/CHRONY:/SBIN/NOLOGIN POLKITD:X:998:996:USER FOR POLKITD:/:/SBIN/NOLOGIN SYSTEMD-BUS-PROXY:X:999:997:SYSTEMD BUS PROXY:/:/SBIN/NOLOGIN DINGJIE:X:1000:1000:DINGJIE:/HOME/DINGJIE:/BIN/BASH JEFF:X:1001:1024:WOSHIDASHUAIBI:/HOME/JEFF:/BIN/BASH EGON:X:1002:1002::/HOME/EGON:/BIN/BASH NFSNOBODY:X:65534:65534:ANONYMOUS NFS USER:/VAR/LIB/NFS:/SBIN/NOLOGIN
5.取出当前主机的IP地址
[root@localhost ~]# ifconfig | egrep "inet.*broadcast.*"|cut -d' ' -f10192.168.0.133
6.列出/etc目录下所有已.conf结尾的文件的文件名,并将其名字转换为大写后保存至/tmp/etc.conf文件中
[root@localhost ~]# find /etc -name '*.conf' | egrep -o "[^/]*(\.conf)$"|tr 'a-z' 'A-Z' >/tmp/etc.conf [root@localhost ~]# cat /tmp/etc.conf RESOLV.CONF CA-LEGACY.CONF FASTESTMIRROR.CONF LANGPACKS.CONF SYSTEMD.CONF VERSION-GROUPS.CONF LVM.CONF LVMLOCAL.CONF ASOUND.CONF LDAP.CONF MLX4.CONF RDMA.CONF SMTPD.CONF
7.显示/var目录下一级子目录或文件的总数
[root@localhost ~]# ls /var | wc -l21
8.取出/etc/group第三个字段数值最小的10个组的名字
[root@localhost ~]# sort -t: -k3 -n /etc/group|head -10 |cut -d':' -f1 root bin daemon sys adm tty disklpmem kmem
9.将/etc/fstab和/etc/issue文件的内容合并为同一个内容后保存至/tmp/etc.test文件中
[root@localhost ~]# cat /etc/fstab /etc/issue > /tmp/etc.test [root@localhost ~]# cat /tmp/etc.test # # /etc/fstab # Created by anaconda on Sat May 13 10:12:58 2017# # Accessible filesystems, by reference, are maintained under '/dev/disk'# See man pages fstab(5), findfs(8), mount(8) and/or blkid(8) for more info#/dev/mapper/cl-root / xfs defaults 0 0UUID=2789d01a-4e2b-47a5-9c3c-537641648663 /boot xfs defaults 0 0/dev/mapper/cl-swap swap swap defaults 0 0\S Kernel \r on an \m
对于正则表达式的使用需要多联系加强记忆,否则是用不好正则表达式的,在学习过程中切记多写多背。
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!