awk linux 数组,Linux中的awk数组的基本使用方法

awk linux 数组,Linux中的awk数组的基本使用方法1.awk数组描述在其他的编程语言中,数组的下标都是从0开始的,也就是说,如果想反向引用数组中的第一个元素,则需要引用对应的下标[0],在awk中数组也是通过引用下标的方法,但是在awk中数组的下标是从1开始的,在其他语言中,你可能会习惯于先“声明”一个数组,在awk中,则不用这样,直接为数组的元素赋值即可(其实如果自己给数组赋值,下标从1或者从0开始那就无所谓了!)2.在声明数组时,可能值很多…

大家好,又见面了,我是你们的朋友全栈君。

1.awk数组描述

在其他的编程语言中,数组的下标都是从0开始的,也就是说,如果想反向引用数组中 的第一个元素,则需要引用对应的下标[0],在awk中数组也是通过引用下标的方法,但是在awk中数组的下标是从1开始的,在其他语言中,你可能会习惯于先“声明”一个数组,在awk中,则不用这样,直接为数组的元素赋值即可(其实如果自己给数组赋值,下标从1或者从0开始那就无所谓了!)

2.在声明数组时,可能值很多,命令太长,降低命令可读性,所以使用反斜杠“\”,来进 行换行,效果是完全一样的,代码如下所示:

[zkpk@master as]$ awk ‘BEGIN{arr[1]=”one”;arr[2]=”two”;arr[3]=”three”\

;arr[4]=”four”;print arr[3]}’

three

[zkpk@master as]$ awk ‘BEGIN{arr[1]=”one”;arr[2]=”two”;arr[3]=”three”;arr[4]=”four”;print arr[3]}’

three

3.数组的元素设置为空,是允许的,当数组中没有某个元素而直接引用它的时候,它默认被赋值为空,所以判断某个元素是否存在,不能采用数组元素值为空的方法,而应该采用下面的方法:

[zkpk@master as]$ awk ‘BEGIN{arr[1]=”one”;arr[2]=”two”;arr[3]=”three”;if(4 in arr){print “four in this arr”}}’

[zkpk@master as]$ awk ‘BEGIN{arr[1]=”one”;arr[2]=”two”;arr[3]=”three”;if(3 in arr){print “three in this arr”}}’

three in this arr

也可以采用取反的方式(使用运算符!)

[zkpk@master as]$ awk ‘BEGIN{arr[1]=”one”;arr[2]=”two”;arr[3]=”three”;if(!(4 in arr)){print “four not in this arr”}}’

four not in this arr

4.awk数组下标

在awk中数组的下标不仅可以是“数字”,还可以是“任意字符串”,其实,awk中的数组本来就是“关联数组”,之所以先用数字作为下标举例子是为了方便之前的习惯,能够有个好的过渡,不过,以数字作为数组的下标在某些场景有一定的优势,但是本质上也是“关联数组”,awk默认会把“数字”下标转换成“字符串”,所以它本质上还是一个使用字符串作为下标的“关联数组”

5.删除数组元素

使用 delete 可以删除数组中的元素,也可以使用 delete 删除整个数组

[zkpk@master as]$ awk ‘BEGIN{arr[1]=”one”;arr[2]=”two”;arr[3]=”three”;\

> delete arr[1];print arr[1]}’

____(空)

[zkpk@master as]$ awk ‘BEGIN{arr[1]=”one”;arr[2]=”two”;arr[3]=”three”;\

print arr[1];print arr[3];delete arr;print arr[1]}’

one

three

____(空)

6.使用for循环遍历数组

语法:for(变量 in 数组名){ 代码语句 }

注:其中变量循环的是数组的下标

[zkpk@master as]$ awk ‘BEGIN{arr[1]=”one”;arr[2]=”two”;arr[3]=”three”;arr[4]=”four”;\

> for ( i in arr){print arr[i]}}’

four

one

two

three

#无序的打印数组元素,进一步证明其是“关联数组”

#有序的打印数组元素

[zkpk@master as]$ awk ‘BEGIN{arr[1]=”one”;arr[2]=”two”;arr[3]=”three”;arr[4]=”four”;\

for ( i=1;i<=4;i++){print arr[i]}}’

one

two

three

four

7.awk数组使用实例

[zkpk@master as]$ awk ‘BEGIN{a=1;print a; a=a+1 ; print a}’

1

2

[zkpk@master as]$ awk ‘BEGIN{a=1;print a; a++ ; print a}’

1

2

将变量a设置为1,对其进行自加运算,则其数值会增加1,这不难理解,那么如果变量a是一个字符串哪?

[zkpk@master as]$ awk ‘BEGIN{a=”test”;print a; a++ ; print a}’

test

当a的值为字符串时,竟然也可以参与运算,而且可以看出,字符串被当成数字0参与运算,那么空字符串参与运算时也会被当成0运算吗?

[zkpk@master as]$ awk ‘BEGIN{a=””;print a; a++ ; print a}’

____(空)

结果显示,空字符串在参与运算时也会被当做数字0,之前我们说过,当我们引用数组中一个不存在的元素,元素被赋值成空字符串,当对这个元素进行自加运算时,元素的值就变成了1,因此当我们对一个不存在的元素进行自加运算后,这个元素的值就变成了自加的次数,自加x次,元素的值就被赋值为x,自加y次元素的值就被赋值为y,所以我们可以通过awk数组的这个特性来统计文本中某字符串出现的次数,代码如下所示

[zkpk@master as]$ cat text

Alice

Bob

Tom

Peter

Alice

Alice

Tom

Bob

Peter

Bob

[zkpk@master as]$ awk ‘{count[$1]++};END{for(i in count){print i,count[i]}}’ text

Bob 3

Tom 2

Alice 3

Peter 2

这回你该发现awk数组这个特性的强大所在了吧,好,也许你会说我不用awk照样可以统计啊,代码如下所示:

[zkpk@master as]$ cat text | sort | uniq -c

3 Alice

3 Bob

2 Peter

2 Tom

好吧,我承认你这个思路很棒,但是你看看下面例子哪?统计文本中人名出现的次数

[zkpk@master as]$ cat -tE text

Alice^IBob$

Bob^IAlice Alice Peter$

Tom Bob$

Peter Alice $

Alice Tom$

Alice^I^ITom $

Tom Peter$

Bob Bob$

Peter Alice$

Bob Alice Alice Tom$

#我们可以看出上面的文本中人名之间的分隔符有制表符,也有空格,来吧,统计人名出现的次数吧,

#我使用awk数组的方式可以这样统计

[zkpk@master as]$ awk ‘{for(i=1;i<=NF;i++){count[$i]++} }END{for(j in count)\

{print j , count[j]}}’ text

Bob 6

Tom 5

Alice 9

Peter 4

但若你不用awk,非得用其他命令实现可以参考如下代码( ^_^ )

[zkpk@master as]$ cat text | tr -s “\t” ” ” | tr -s ” ” “\n” | sort | uniq -c

9 Alice

6 Bob

4 Peter

5 Tom

结尾

本文介绍了awk数组的基本使用方法,但是要学会灵活的运用,我在上面的示例中也写出了一些可以在某种程度上替换awk数组的方式,所以本文不单单是介绍awk数组该如何使用,而是如何在合适的场景,选择出最优的解决方案,快速高效的解决问题。这就是我一直追求的,也是我学习Linux命令的真实意图。

以上所述是小编给大家介绍的Linux中的awk数组的基本使用方法,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对脚本之家网站的支持!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/161632.html原文链接:https://javaforall.cn

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)


相关推荐

  • pycharm安装python3.6_python安装教程

    pycharm安装python3.6_python安装教程Pycharm安装+python3.9+配置过程一、安装Pycharm+python3.9Pycharm官网下载:https://www.jetbrains.com/pycharm/download/#section=windows点击Community下的Download进行下载。Python3.9官网下载:https://www.python.org/点击Download下的python3.9.2进入:下拉至最下面,点击windowsem

  • (c,c++,java)爱心代码(狗粮)

    (c,c++,java)爱心代码(狗粮)今天(2019/8/7)是七夕,撒一波狗粮!有些人对计算机类的学生和程序员们有一点的误解,这是不对的。其实当他们浪漫起来的时候就没有其他人什么事了哈哈c款狗粮:#include<stdio.h>#include<math.h>intmain(){ printf(“\n”); printf(“\n”); printf(“\n”); printf(“…

    2022年10月13日
  • mybatis拦截器详解_短信拦截器

    mybatis拦截器详解_短信拦截器Mybatis拦截器介绍目录前言Interceptor接口注册拦截器Mybatis可拦截方法利用拦截器进行分页  拦截器的一个作用就是我们可以拦截某些方法的调用,我们可以选择在这些被拦截的方法执行前后加上某些逻辑,也可以在执行这些被拦截的方法时执行自己的逻辑而不再执行被拦截的方法。Mybatis拦截器设计的一个初衷就是为了供用户在某些时候可以实现自己的逻辑而不必去动Mybatis…

  • a 标签去掉下划线[通俗易懂]

    a 标签去掉下划线[通俗易懂]text-decoration:none

  • FFMPEG 实现 YUV,RGB各种图像原始数据之间的转换(swscale)

    FFMPEG 实现 YUV,RGB各种图像原始数据之间的转换(swscale)FFMPEG中的swscale提供了视频原始数据(YUV420,YUV422,YUV444,RGB24…)之间的转换,分辨率变换等操作,使用起来十分方便,在这里记录一下它的用法。swscale主要用于在2个AVFrame之间进行转换。下面来看一个视频解码的简单例子,这个程序完成了对”北京移动开发者大会茶歇视频2.flv”(其实就是优酷上的一个普通视频)的解码工作,并将解码后的数据保存为原始数据文件(例如YUV420,YUV422,RGB24等等)。其中略去了很多的代码。注:完整代码在文章:100

  • Fork/Join框架基本使用[通俗易懂]

    1.概述ava.util.concurrent.ForkJoinPool由Java大师DougLea主持编写,它可以将一个大的任务拆分成多个子任务进行并行处理,最后将子任务结果合并成最后的计算结果,并进行输出。本文中对Fork/Join框架的讲解,基于JDK1.8+中的Fork/Join框架实现,参考的Fork/Join框架主要源代码也基于JDK1.8+。这几篇文章将试图解释Fork/…

发表回复

您的电子邮箱地址不会被公开。

关注全栈程序员社区公众号