echo命令和awk命令

echo用来输出内容,比如,echo -e ‘hello linux system\nmy name is bigboy.’。-e,表示若输出内容有特殊符号,则按特殊符号输出。上个命令的输出是:

hello linux system

my name is big boy.

若没有-e,比如echo -e ‘hello linuxsystem\nmy name is big boy.’则把\n当做普通字符显示输出。具体输出内容是:

hello linux system\nmy nameis big boy.

echo后面跟着的参数意义有:

-e 若字符串中出现以下字符,则特别加以处理,而不会将它当成一般
文字输出:
\a 发出警告声;
\b 删除前一个字符;
\c 最后不加上换行符号;
\f 换行但光标仍旧停留在原来的位置;
\n 换行且光标移至行首;
\r 光标移至行首,但不换行;
\t 插入tab;
\v 与\f相同;
\\ 插入\字符;
\nnn 插入nnn(八进制)所代表的ASCII字符;
–help 显示帮助
–version 显示版本信息

 

awk命令

这个命令很好用,可以按照指定字符分割文本内容,比如

echo ‘heloo,3hi,big,boy’ | awk -F, '{print $0}'

这个命令的意思就是,将输出内容  heloo,3hi,big,boy 按逗号,进行切分 heloo3hi big boy,然后将切分后的所有内容输出。所以上述命令的输出内容是:

heloo 3hi big boy

awk 其他的命令,比如 $NF,各个域的值做数学运算。这里推荐一个网址的介绍,参考学习,感觉很好。

https://linux.cn/article-3945-1.html

 

默认情况下,awk通过空格分隔输入。如果您想选择输入的第一个字段,你只需要告诉awk输出$ 1:

  1. $echo'one two threefour' |awk'{print$1}'

one

(是的,大括号语法是有点古怪,但我保证这是我们这节课一直会遇到。)

你能猜出如何选择第二,第三或第四个字段么?是的,分别用$2,$ 3,$ 4。

  1. $echo'one two threefour' |awk'{print$3}'

three

通常在文本改写时,你需要创建一个特定的数据格式,并且它覆盖不止一个单词。好消息是,awk中可以很容易地打印多个字段,甚至包含静态字符串:

  1. $echo'one two threefour' |awk'{print$3,$1}'

three one

  1. $echo'one two threefour' |awk'{print"foo:",$3,"| bar:",$1}'

foo: three | bar: one

好吧,如果你的输入不是由空格分隔怎么办?只需用awk中的'-F'标志指定你的分隔符:

  1. $echo'onemississippi,two mississippi,three mississippi,fourmississippi' |awk-F,'{print$4}'

four mississippi

偶尔间,你会发现自己正在处理字段数量不同的数据,但你只知道你想要的最后字段。awk中内置的$NF变量代表字段的数量,这样你就可以用它来抓取最后一个元素:

  1. $echo'one two threefour' |awk'{print$NF}'

four

你也可以用$NF做简单的数学,假如你需要倒数第二个字段:

  1. $echo'one two threefour' |awk'{print$(NF-1)}'

three

甚至是中间的字段:

  1. $echo'one two threefour' |awk'{print$((NF/2)+1)}'

three

而且这一切都非常有用,同样你可以摆脱强制使用sed,cut,和grep来得到这些结果(尽管要做更多的操作)。

因此,我将最后为你介绍awk的一个特性,维持跨行状态。

  1. $echo-e'one 1\ntwo2' |awk'{print$2}'

1

2

  1. $echo-e'one 1\ntwo2' |awk'{sum+=$2} END{print sum}'

3

(END代表的是我们在执行完每行的处理之后只处理下面的代码块)

这里我使用的例子是统计web服务器请求日志的字节大小。想象一下我们有如下这样的日志:

  1. $catrequests.log

Jul 23 18:57:12 httpd[31950]: "GET /foo/bar HTTP/1.1" 200 344

Jul 23 18:57:13 httpd[31950]: "GET / HTTP/1.1" 200 9300

Jul 23 19:01:27 httpd[31950]: "GET / HTTP/1.1" 200 9300

Jul 23 19:01:55 httpd[31950]: "GET /foo/baz HTTP/1.1" 200 6401

Jul 23 19:02:31 httpd[31950]: "GET /foo/baz?page=2 HTTP/1.1" 2006312

我们知道最后一个字段是响应的字节大小。我们已经学习了如何使用$NF来抽取他们:

  1. $<</span>requests.logawk '{print$NF}'

344

9300

9300

6401

6312

接着我们可以将它们累加到一个变量中来收集我们的web服务其在日志中这段时间内的响应客户端的字节数量

  1. $<</span>requests.logawk '{totalBytes+=$NF}END {print totalBytes}'

31657

如果你正在寻找关于awk的更多资料,你可以在Amazon中花费不到15美元买到原始awk手册的二手书。你也许还可以看看EricPement的单行awk命令收集这本书。

  • 2
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值