grep

 grep

通配符类型详解:
*                                         0个或者多个字符、数字;
?                                        匹配任意一个字符;
#                                        表示注解;
|                                         管道符号;
;                                         多个命令连续执行;
&                                       后台运行指令;
!                                         逻辑运算非;
[ ]                                       内容范围,匹配括号中内容;
{ }                                       命令块,多个命令匹配。
正则表达式详解:
*                                         前一个字符匹配0次或多次;
.                                         匹配除了换行符以外任意一个字符;
.*                                        代表任意字符;
^                                        匹配行首,即以某个字符开头;
$                                        匹配行尾,即以某个字符结尾;
\(..\)                                   标记匹配字符;
[]                                        匹配中括号里的任意指定字符,但只匹配一个字符;
[^]                                     匹配除中括号以外的任意一个字符;
\                                         转义符,取消特殊含义;
\<                                      锚定单词的开始;
\>                                      锚定单词的结束;
{n}                                     匹配字符出现n次;
{n,}                                  匹配字符出现大于等于n次;
{n,m}                                 匹配字符至少出现n次,最多出现m次;
\w                                      匹配文字和数字字符,不匹配符号;
\W                                     \w的反置形式,匹配一个或多个非单词字符,匹配符号;
\b                                      单词锁定符;
\s                                       匹配任何空白字符;
\d                                      匹配一个数字字符,等价于[0-9]。
常用GREP工具企业演练案列:
grep  -c "test"    1.txt           #统计test字符总行数;
grep  -i "TEST"   1.txt           #不区分大小写查找TEST所有的行;
grep  -n "test"  1.txt            #打印test的行及行号;
grep  -v "test"  1.txt            #不打印test的行;
grep  "test[53]"  1.txt          #以字符test开头,接5或者3的行;
grep  "^[^test]"  1.txt         #显示输出行首不是test的行;
grep  "[Mm]ay"  1.txt         # 匹配M或m开头的行;
grep  "K…D"  1.txt             #匹配K,三个任意字符,紧接D的行;
grep  "[A-Z][9]D"  1.txt      #匹配大写字母,紧跟9D的字符行;
grep  "T\{2,\}"  1.txt          #打印字符T字符连续出现2次以上的行;
grep  "T\{4,6\}"  1.txt        #打印字符T字符连续出现4次及6次的行;
grep  -n "^$"  1.txt          #打印空行的所在的行号;
grep  -vE "#|^$"  1.txt      #不匹配文件中的#和空行;
grep  --color -ra -E "db|config|sql"  *  #匹配包含db或者config或者sql的文件;
grep  --color -E "\<([0-9]{1,3}\.){3}([0-9]{1,3})\>" 1.txt   #匹配IPV4地址。

找出当前目录纯数字的文件或目录

ls |  grep -E  ^[0-9]+$  

找出当前目录纯数字的文件(只找文件)
ls -l  | grep ^- | awk '{print $NF}'| grep -E ^[0-9]+$

匹配IP地址

IP其中一位: "[0-9]{1,3}"
IP四位:  "[0-9]{1,3},[0-9]{1,3},[0-9]{1,3},[0-9]{1,3}"
可以缩写为: grep -oE  "([0-9]{1,3}\.){3}[0-9]{1,3}"
. 号可以加反斜杠,避免有歧异
  
如果IP地址超过255也能匹配,所以需要进一步优化
把IP分为4个段,然后循环比较数值大小
提示:可以把命令结果设置为变量

定义数组变量

格式:数组名=(值1  值2  。。。。)  值中间使用空格分开
 
@全部值:echo ${LAMP[@]}
 
参数个数:echo ${#LAMP[@]}
 
示例:把IP地址设置为数组
思路:使用sed把.替换成空格 sed ‘s/\./ /g’
 
再定义数组:IP=($(grep –oE “xxxxx” file.txt ))
 
 

 

 
posted @ 2022-10-11 08:59  此生逍遥py  阅读(100)  评论(0)    收藏  举报