linux 命令之 alias、grep
alias
alias
用来设置指令的别名,可以使用该命令将一些较长的命令简化。并且原命令必须使用 ''
单引号引起来,防止特殊字符产生错误。
alias
命令只会在当前登入产生影响,如果想永久设置,需要将相应的 alias
命令放入 bash 的初始化文件/etc/bashrc
中。
- 语法
alias [选项] [参数]
选项
:-p:打印已经设置的命令别名
参数
: 命令别名设置:定义命令别名,格式为“命令别名=‘实际命令’”
用法
:alias 新命令='原命令 -选项或参数'
,例如 alias l='ls -lsh'
unalias
命令可以删除一个别名,例如unalias l
- 直接输入 alias 命令会列出当前系统中所有已经定义的命令别名,可以使用
grep
命令对结果进行筛选,如alias | grep "git stash"
/alias | grep stash
grep
grep
(global search regular expression and print out the line,全面搜索正则表达式并把行打印出来)是一个强大的文本搜索工具,能够使用正则表达式搜索文本并把行打印出来。
-
用法
grep [选项1] [选项2] ... match_pattern file_1 grep [选项1] [选项2] ... "match_pattern" file_1 grep [选项1] [选项2] ... match_pattern file_1 file_2 file_3 ...
选项:
# **注意大小写不通用!!** # 选项的位置可以在 pattern 前面、 pattern 后面、或者 file_name 后面 -a 不要忽略二进制数据。 -A <显示列数> 除了显示符合范本样式的那一行之外,并显示该行之后的内容。 -b 在显示符合范本样式的那一行之外,并显示该行之前的内容。 -c 计算符合范本样式的列数。 -C <显示列数>或-<显示列数> 除了显示符合范本样式的那一列之外,并显示该列之前后的内容。 -d <进行动作> 当指定要查找的是目录而非文件时,必须使用这项参数,否则grep命令将回报信息并停止动作。 -e <范本样式> 指定字符串作为查找文件内容的范本样式。 -E 将范本样式为延伸的普通表示法来使用,意味着使用能使用扩展正则表达式。 -f <范本文件> 指定范本文件,其内容有一个或多个范本样式,让grep查找符合范本条件的文件内容,格式为每一列的范本样式。 -F 将范本样式视为固定字符串的列表。 -G 将范本样式视为普通的表示法来使用。 -h 在显示符合范本样式的那一列之前,不标示该列所属的文件名称。 -H 在显示符合范本样式的那一列之前,标示该列的文件名称。 -i 忽略字符大小写的差别。 -l 列出文件内容符合指定的范本样式的文件名称。 -L 列出文件内容不符合指定的范本样式的文件名称。 -n 在显示符合范本样式的那一列之前,标示出该列的编号。 -q 不显示任何信息。 -R/-r 此参数的效果和指定“-d recurse”参数相同。 -s 不显示错误信息。 -v 反转查找。 -w 只显示全字符合的列。 -x 只显示全列符合的列。 -y 此参数效果跟“-i”相同。 -o 只输出文件中匹配到的部分。
常见用法:
-
-v
输出不符合 pattern 的行:grep -v "match_pattern" file_name
-
-E
使用正则表达式:grep -E "[1-9]+"
/egrep "[1-9]+"
-
-e
可以匹配多个样式:echo this is a text line | grep -e "is" -e "line" -o
-
-f
匹配存储在样式文件中的多个样式:echo this is a text line | grep -f patfile -o
-
-o
只输出文件中匹配到的部分:echo this is a test line. | grep -o -E "[a-z]+."
/echo this is a test line. | egrep "[a-z]+."
-
-c
统计文件或者文本中包含匹配字符串的行数:grep -c "text" file_name
-
-l
查找多个文件并输出匹配的文本在那些文件中:grep -l "text" file_1 file_2
-
-i
忽略匹配样式中的字符大小写:echo "hello world" | grep -i "HELLO"
-
--color=auto
标记匹配颜色选项:grep "match_pattern" file_name --color=auto
-
-n
输出包含匹配字符串的结果中附带行数(第几行):grep "text" -n file_name
/cat file_name | grep "text" -n
-
递归搜索文件:
grep "text" . -r -n
/grep "text . -rn"
输出中会有所在文件和行索引数 -
在
grep
的结果中筛选包括或者排除指定文件:grep "text" . -r --include *.{php,html}
grep "text" . -r --exclude "REDEME"
grep "text" . -r --exclude-from filelist
从搜索结果中排除 filelist 中的文件
-
-0
使用0值字节后缀的grep
与xargs
:-
# 测试文件: echo "aaa" > file1 echo "bbb" > file2 echo "aaa" > file3 grep "aaa" file* -lZ | xargs -0 rm #执行后会删除file1和file3,grep输出用-Z选项来指定以0值字节作为终结符文件名( ),xargs -0 读取输入并用0值字节终结符分隔文件名,然后删除匹配文件,-Z通常和-l结合使用。
-
-