shell 陌生命令记录

awk

内置变量表

属性说明
$0当前记录(作为单个变量)
1   1~ 1 n当前记录的第n个字段,字段间由FS分隔, 最大100
FS输入字段分隔符 默认是空格
NF当前记录中的字段个数,就是有多少列
NR已经读出的记录数,就是行号,从1开始
RS输入的记录他隔符默 认为换行符
OFS输出字段分隔符 默认也是空格
ORS输出的记录分隔符,默认为换行符
ARGC命令行参数个数
ARGV命令行参数数组
FILENAME当前输入文件的名字
IGNORECASE如果为真,则进行忽略大小写的匹配
ARGIND当前被处理文件的ARGV标志符
CONVFMT数字转换格式 %.6g
ENVIRONUNIX环境变量
ERRNOUNIX系统错误消息
FIELDWIDTHS输入字段宽度的空白分隔字符串
FNR当前记录数
OFMT数字的输出格式 %.6g
RSTART被匹配函数匹配的字符串首
RLENGTH被匹配函数匹配的字符串长度
SUBSEP\034

sed

#sed的常用选项:

-r:使用扩展正则表达式

-e:它告诉sed将下一个参数解释为一个sed指令,只有当命令行上给出多个sed指令时才需要使用-e选项

-f:后跟保存了sed指令的文件

-i:直接对内容进行修改,不加-i时默认只是预览,不会对文件做实际修改

-n:取消默认输出,sed默认会输出所有文本内容,使用-n参数后只显示处理过的行

#sed中的编辑命令:

a:追加  向匹配行后面插入内容

c:更改  更改匹配行的内容

i:插入  向匹配行前插入内容

d:删除  删除匹配的内容

s:替换  替换掉匹配的内容

p:打印  打印出匹配的内容,通常与-n选项和用

=:用来打印被匹配的行的行号

n:读取下一行,遇到n时会自动跳入下一行

r,w:读和写编辑命令,r用于将内容读入文件,w用于将匹配内容写入到文件

#替换标志
g	在行内进行全局替换
p	打印行
w	将行写入文件
x	交换暂存缓冲区和模式空间的内容
y	将字符转换成另外一个字符

grep

-a --text # 不要忽略二进制数据。 
-A <显示行数> --after-context=<显示行数> # 除了显示符合范本样式的那一行之外,并显示该行之后的内容。  
-b --byte-offset # 在显示符合范本样式的那一行之外,并显示该行之前的内容。  
-B<显示行数> --before-context=<显示行数> # 除了显示符合样式的那一行之外,并显示该行之前的内容。  
-c --count # 计算符合范本样式的列数。  
-C<显示行数> --context=<显示行数>或-<显示行数> # 除了显示符合范本样式的那一列之外,并显示该列之前后的内容。  
-d<进行动作> --directories=<动作> # 当指定要查找的是目录而非文件时,必须使用这项参数,否则grep命令将回报信息并停止动作。  
-e<范本样式> --regexp=<范本样式> # 指定字符串作为查找文件内容的范本样式。  
-E --extended-regexp # 将范本样式为延伸的普通表示法来使用,意味着使用能使用扩展正则表达式。  
-f<范本文件> --file=<规则文件> # 指定范本文件,其内容有一个或多个范本样式,让grep查找符合范本条件的文件内容,格式为每一列的范本样式。  
-F --fixed-regexp # 将范本样式视为固定字符串的列表。  
-G --basic-regexp # 将范本样式视为普通的表示法来使用。  
-h --no-filename # 在显示符合范本样式的那一列之前,不标示该列所属的文件名称。  
-H --with-filename # 在显示符合范本样式的那一列之前,标示该列的文件名称。  
-i --ignore-case # 忽略字符大小写的差别。  
-l --file-with-matches # 列出文件内容符合指定的范本样式的文件名称。  
-L --files-without-match # 列出文件内容不符合指定的范本样式的文件名称。  
-n --line-number # 在显示符合范本样式的那一列之前,标示出该列的编号。  
-q --quiet或--silent # 不显示任何信息。  
-R/-r --recursive # 此参数的效果和指定“-d recurse”参数相同。  
-s --no-messages # 不显示错误信息。  
-v --revert-match # 反转查找。  
-V --version # 显示版本信息。  
-w --word-regexp # 只显示全字符合的列。  
-x --line-regexp # 只显示全列符合的列。  
-y # 此参数效果跟“-i”相同。  
-o # 只输出文件中匹配到的部分。

#常用选项
-v: 反向选取
-o:仅显示匹配的字串,而非字串所在的行
-i:ignore-case,忽略字符大小写
-A:显示之后两行
-B:显示之前两行
-C:显示上下两行


grep 正则匹配

^        # 锚定行的开始 如:'^grep'匹配所有以grep开头的行。 
$        # 锚定行的结束 如:'grep$'匹配所有以grep结尾的行。 
.        # 匹配一个非换行符的字符 如:'gr.p'匹配gr后接一个任意字符,然后是p。 
* 		 # 匹配零个或多个先前字符 如:'*grep'匹配所有一个或多个空格后紧跟grep的行。 
.*       # 一起用代表任意字符。 [] # 匹配一个指定范围内的字符,如'[Gg]rep'匹配Grep和grep。 
[^]         # 匹配一个不在指定范围内的字符,如:'[^A-FH-Z]rep'匹配不包含A-R和T-Z的一个字母开头,紧跟rep的行。 
\(..\)      # 标记匹配字符,如'\(love\)',love被标记为1。 同egrep:(..)  
\<        # 锚定单词的开始,如:'\<grep'匹配包含以grep开头的单词的行。 
\>        # 锚定单词的结束,如'grep\>'匹配包含以grep结尾的单词的行。 
x\{m\}       # 重复字符x,m次,如:'0\{5\}'匹配包含5个o的行。 同egrep:{..} 
x\{m,\}      # 重复字符x,至少m次,如:'o\{5,\}'匹配至少有5个o的行。x\{m,n\} # 重复字符x,至少m次,不多于n次,如:'o\{5,10\}'匹配5--10个o的行。 
\w           # 匹配文字和数字字符,也就是[A-Za-z0-9],如:'G\w*p'匹配以G后跟零个或多个文字或数字字符,然后是p。 
\W              # \w的反置形式,匹配一个或多个非单词字符,如点号句号等。 
\b              # 单词锁定符,如: '\bgrep\b'只匹配grep。 

#egrep 扩展
+		#匹配一个或多个先前的字符。如:'[a-z]+able',匹配一个或多个小写字母后跟able的串,如loveable,enable,disable等。
?		#匹配零个或多个先前的字符。如:'gr?p'匹配gr后跟一个或没有字符,然后是p的行。
a|b|c	#匹配a或b或c。如:grep|sed匹配grep或sed
()		#分组符号,如:love(able|rs)ov+匹配loveable或lovers,匹配一个或多个ov。
x{m},x{m,},x{m,n}	#作用同x/{m/},x/{m,/},x/{m,n/}

SS

ss是Socket Statistics的缩写, 它能够显示更多更详细的有关TCP和连接状态的信息,而且比netstat更快速更高效。

ss -t -a 【显示TCP连接】

-h, --help 帮助
-V, --version 显示版本号
-t, --tcp 显示 TCP 协议的 sockets
-u, --udp 显示 UDP 协议的 sockets
-x, --unix 显示 unix domain sockets,与 -f 选项相同
-n, --numeric 不解析服务的名称,如 “22” 端口不会显示成 “ssh”
-l, --listening 只显示处于监听状态的端口
-p, --processes 显示监听端口的进程(Ubuntu 上需要 sudo)
-a, --all 对 TCP 协议来说,既包含监听的端口,也包含建立的连接
-r, --resolve 把 IP 解释为域名,把端口号解释为协议名称

watch

watch可以帮你周期性的执行下个程序, 监测一个命令的运行结果

watch -n 1 free : 每隔一秒钟检测一次

-n或–intervalwatch缺省每2秒运行一下程序,可以用-n或-interval来指定间隔的时间。
-d或–differences用 -d 或 –differences 选项,watch 会高亮显示变化的区域。而-d=cumulative选项会把变动过的地方(不管最近的那次有没有变动)都高亮显示出来。
-t 或 -no-title会关闭watch命令在顶部的时间间隔,命令,当前时间的输出。
-h,–help 查看帮助文档
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 好的,您可以在终端中输入需要执行的命令,例如: ``` ls -l ``` 这将列出当前目录下的文件和文件夹,并显示详细信息。您也可以执行其他命令,例如: ``` cd /path/to/directory ``` 这将切换到指定目录。请注意,在执行命令时,请仔细检查输入的命令是否正确,以避免不必要的问题。 ### 回答2: Shell是一种命令解释器,它可以执行用户输入的命令并与操作系统进行交互。用户可以通过Shell来执行各种命令,包括系统命令、自定义命令和脚本文件。 在Shell中执行命令的一般语法是:命令 [选项] [参数]。通过命令可以实现各种功能,比如创建目录、复制文件、查看文件内容等等。 Shell执行命令的过程如下: 1. 用户通过Shell输入命令并按下回车键。 2. Shell解析命令,判断是否为系统命令、自定义命令还是脚本文件。 3. 如果是系统命令Shell会在系统路径中查找该命令的可执行文件,并加载到内存中执行。 4. 如果是自定义命令Shell会查找用户定义的命令,并执行相应的操作。 5. 如果是脚本文件,Shell会读取脚本文件中的命令,并按顺序执行。 在执行命令时,可以通过选项和参数来实现不同的功能。选项通常以"-"开头,用来修改命令的行为,比如指定输出格式、忽略警告等。参数用来指定命令的操作对象,比如文件名、目录名等。 Shell执行命令的结果会显示在终端上。如果命令执行成功,通常会显示执行结果或者不显示任何信息。如果命令执行失败,通常会显示错误信息,供用户参考和排查问题。 总而言之,Shell是一个功能强大的命令行工具,通过执行命令可以实现各种功能。无论是初学者还是有经验的开发人员,都需要掌握Shell命令的使用,以便更高效地操作和管理系统。 ### 回答3: Shell 是一种解释型的命令行界面,用于与操作系统进行交互。通过 Shell,我们可以执行各种命令,完成文件操作、进程管理、网络通信等任务。 要执行一个命令,首先需要打开一个 Shell 终端。在终端中,我们可以输入命令并按下回车键执行。命令的语法通常由指令和参数组成。指令指定要执行的操作,而参数则提供指令所需的输入。 例如,要在 Shell 中执行一个简单的命令,比如打印当前日期和时间,我们可以使用 `date` 指令。在终端中输入 `date` 并按下回车键,系统会立即执行该命令,并将输出结果显示在终端中。 除了单个命令外,Shell 还支持通过脚本文件执行多条命令。我们可以将一系列命令按照特定的顺序编写到一个脚本文件中,然后通过 Shell 执行该脚本文件,以便一次性运行多个命令Shell 还提供了一些特殊的符号和操作符,用于执行更复杂的命令操作,比如管道符号 `|` 用于将一个命令的输出作为另一个命令的输入,或者重定向符号 `>` 和 `<` 用于将命令执行结果输出到文件中,或从文件中读取输入。 总的来说,Shell 执行命令是通过输入指令和参数到 Shell 终端中,并按下回车键进行执行。借助于命令行界面和各种符号操作,我们可以实现丰富的操作和功能,并高效地管理和控制操作系统。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值