### 字符匹配
. 代表任意单个字符,包括不仅限于字母、汉字、数字。
例:grep "谈..狗" 文件名 匹配以谈为首,以狗为尾的四字词语。
[] 代表匹配内容范围,指定任意数量单个字符(输入多个字符分开匹配)
例:grep "[0-9]" 文件名 匹配所有包含数字的内容
grep "[五月天]"文件名 匹配五、月、天三个字
[^] 代表匹配内容之外,指定任意数量单个字符(输入多个字符分开匹配)
例:grep "[^0-9]" 文件名 匹配所有不包含数字的内容
[:space:] 代表空格、Tap、换行、回车等各种类型的空白符
[:punct:] 代表标点符号
------
### 次数匹配
*代表匹配*前面的字符出现了任意次,包括0次
例:grep "五月天*" 文件名 匹配包含五月天的行,亦或是五月地,五月1
? 代表匹配?前面的字符出现了1次或0次,即可有可无,零或非零
+代表匹配+前面的字符出现了至少一次
{n} 代表匹配{n} 前面的字符n次
{m,n} 代表匹配{m,n} 前面的字符至少m次,至多n次
------
### 位置锚定
^ 代表匹配行首
例:gerp "^五月天"文件名 匹配以五月天为首的行
$ 代表匹配行尾
例:gerp "五月天$"文件名 匹配以五月天为尾的行
\b 代表匹配词首或词尾
例:gerp"\b五月" 匹配以五月为首的词
gerp"五月\b" 匹配以五月为尾的词
------
### 分组其他
() 匹配括号内字符串,将括号内视为一个整体
例: grep -E"(五月天)"文件名 匹配五月天这个字符串
| 或的方式匹配多个字符串
例: grep -E "五月天|周杰伦"文件名 匹配包含五月天或者周杰伦的行
\ 转义字符,针对检索特殊含义的字符
例:grep "\'" 文件名 转义匹配包含'的行
'' 强引用 内部所有特殊意义的字符全部不生效
"" 弱引用 内部特定的特殊字符可生效
------
### 通配符
通配符与正则表达式适用场景不同,符号所代表的意思也不相同,一般只用于文件名匹配
"*"匹配零个或多个字符,但不匹配以.为首的隐藏文件
? 匹配任意单个字符,包括不仅限于汉字
~ 当前家目录
| 管道符,将前置内容的输出作为后置内容的输入
= 变量赋值,设定一个变量,将前者等同后者运算
$ 变量引用,取变量值或取运算值
\ 输入长命令时,可使用\换行
">"输出内容重定向,输入文件中会覆盖原内容
">>"输出内容追加重定向,输入文件中会在原内容基础上追加
< 输入内容重定向
<< 输入内容追加重定向
&> 将标准输出和标准错误都重定向
"#"注释,表示该行内容为注解,不实际生效
[] 括号内可设置一个范围
{} 括号内可设置一个序列,以逗号分隔,不支持空格
&& 并且,表示前者和后者并列关系
|| 或者,表示前者和后者或者关系
------
### tr与tee
tr '123''xyz' 后者字符转换为前者,接下来信息123会分别转换为xyz。
tr '12345' 'xyz' 前者字符多余后者,多出来的字符全部都会转换为最后的字符。
tr 'A-Z' 'a-z' 接下来的信息大写全部转换为小写。
tr -d '字符' 接下来的信息只要出现指定字符就会删除。
tr -s '字符' 接下来的信息,只要出现相同并连续的指定字符,都会压缩成一个。
tee配合管道符使用,可以重定向到多个目标
命令1 | tee 文件名 | 命令2 将命令1的执行结果放在文件中,又不影响作为命令2的输入。
命令1 | tee -a 文件名 | 命令2 结果放在文件时不覆盖原有信息,而是追加
------
------