`
huiminchen
  • 浏览: 75852 次
  • 性别: Icon_minigender_2
  • 来自: 北京
社区版块
存档分类
最新评论

【转】awk 数组介绍

 
阅读更多

转自:http://www.cnblogs.com/chengmo/archive/2010/10/08/1846190.html

 

 

用awk进行文本处理,少不了就是它的数组处理。那么awk数组有那些特点,一般常见运算又会怎么样呢。我们先看下下面的一些介绍,结合例子我们会讲解下它的不同之处。在 awk 中数组叫做关联数组(associative arrays),因为下标记可以是数也可以是串。awk 中的数组不必提前声明,也不必声明大小。数组元素用 0 或空串来初始化,这根据上下文而定。例如:

 

一、定义方法

 

1:可以用数值作数组索引(下标)

Tarray[1]=“cheng mo”
Tarray[2]=“800927”

2:可以用字符串作数组索引(下标)

Tarray[“first”]=“cheng ”
Tarray[“last”]=”mo”
Tarray[“birth”]=”800927”

使用中 print Tarray[1] 将得到”cheng mo” 而 print Tarray[2] 和 print[“birth”] 都将得到 ”800927” 。

 

二、数组相关函数

[chengmo@localhost ~]$ awk --version
GNU Awk 3.1.5

使用版本是:3.1以上,不同版本下面函数不一定相同

  • 得到数组长度(length方法使用

[chengmo@localhost ~]$ awk 'BEGIN{info="it is a test";lens=split(info,tA," ");print length(tA),lens;}'
4 4

length返回字符串以及数组长度,split进行分割字符串为数组,也会返回分割得到数组长度。

 

(asort使用):

[chengmo@localhost ~]$ awk 'BEGIN{info="it is a test";split(info,tA," ");print asort(tA);}'
4

asort对数组进行排序,返回数组长度。

 

  • 输出数组内容(无序,有序输出):

[chengmo@localhost ~]$ awk 'BEGIN{info="it is a test";split(info,tA," ");for(k in tA){print k,tA[k];}}'
4 test
1 it
2 is
3 a

 

for…in 输出,因为数组是关联数组,默认是无序的。所以通过for…in 得到是无序的数组。如果需要得到有序数组,需要通过下标获得。

 

[chengmo@localhost ~]$ awk 'BEGIN{info="it is a test";tlen=split(info,tA," ");for(k=1;k<=tlen;k++){print k,tA[k];}}' 
1 it
2 is
3 a
4 test

注意:数组下标是从1开始,与c数组不一样。

 

 

  • 判断键值存在以及删除键值:

一个错误的判断方法

[chengmo@localhost ~]$ awk 'BEGIN{tB["a"]="a1";tB["b"]="b1";if(tB["c"]!="1"){print "no found";};for(k in tB){print k,tB[k];}}' 
no found
a a1
b b1
c

 

以上出现奇怪问题,tB[“c”]没有定义,但是循环时候,发现已经存在该键值,它的值为空,这里需要注意,awk数组是关联数组,只要通过数组引用它的key,就会自动创建改序列.

 

正确判断方法:

[chengmo@localhost ~]$ awk 'BEGIN{tB["a"]="a1";tB["b"]="b1";if( "c" in tB){print "ok";};for(k in tB){print k,tB[k];}}'  
a a1
b b1

if(key in array) 通过这种方法判断数组中是否包含”key”键值。

 

删除键值:

[chengmo@localhost ~]$ awk 'BEGIN{tB["a"]="a1";tB["b"]="b1";delete tB["a"];for(k in tB){print k,tB[k];}}'                     
b b1

 

delete array[key]可以删除,对应数组key的,序列值。

 

三、二维数组使用(多维数组使用)

awk的多维数组在本质上是一维数组,更确切一点,awk在存储上并不支持多维数组。awk提供了逻辑上模拟二维数组的访问方式。例 如,array[2,4] = 1这样的访问是允许的。awk使用一个特殊的字符串SUBSEP (\034)作为分割字段,在上面的例子中,关联数组array存储的键值实际上是2\0344。

 

类似一维数组的成员测试,多维数组可以使用 if ( (i,j) in array)这样的语法,但是下标必须放置在圆括号中。
类似一维数组的循环访问,多维数组使用 for ( item in array )这样的语法遍历数组。与一维数组不同的是,多维数组必须使用split()函数来访问单独的下标分量。split ( item, subscr, SUBSEP)

 

[chengmo@localhost ~]$ awk 'BEGIN{

for(i=1;i<=9;i++)
{
  for(j=1;j<=9;j++)  
  {
tarr[i,j]=i*j;
print i,"*",j,"=",tarr[i,j];
  }
}
}'
1 * 1 = 1
1 * 2 = 2
1 * 3 = 3
1 * 4 = 4
1 * 5 = 5
1 * 6 = 6

……

可以通过array[k,k2]引用获得数组内容.

 

方法二:

[chengmo@localhost ~]$ awk 'BEGIN{
for(i=1;i<=9;i++)
{
  for(j=1;j<=9;j++)  
  {
tarr[i,j]=i*j;
  }
}
for(m in tarr)              
{

split(m,tarr2,SUBSEP);
print tarr2[1],"*",tarr2[2],"=",tarr[m];
}
}'

 

以上是awk对数组的处理相关,希望对大家有用。

分享到:
评论

相关推荐

    用awk数组处理两个文件

    数组是`awk`中的一个重要概念,它允许我们存储和操作一组相关数据。本篇文章将详细讲解如何使用`awk`数组来处理两个文件,以及在不同场景下的应用。 在给定的例子中,有两个文件`a`和`b`,目标是找出`a`文件中与`b`...

    awk数组.xmind

    自己总结的awk数组相关的思维导图文件,可以下载xmind进行打开,第一次上传文件,多多赐教

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

    以下将详细介绍Linux中awk数组的基本使用方法。 1. **数组描述** 在awk中,数组的下标从1开始,不同于许多其他编程语言从0开始。这意味着访问数组的第一个元素时,你应该使用`arr[1]`。awk中的数组不需要预先声明...

    Linux Awk数组操作详细介绍

    那么awk数组有那些特点,一般常见运算又会怎么样呢。我们先看下下面的一些介绍,结合例子我们会讲解下它的不同之处。在 awk 中数组叫做关联数组(associative arrays),因为下标记可以是数也可以是串。awk 中的数组...

    awk数组实战

    本主题聚焦于`awk`的数组应用,将深入探讨如何利用`awk`处理数组,以实现对复杂数据集的分析和操作。 数组在`awk`中扮演着核心角色,它允许我们存储和处理一组相关的数据。与许多编程语言不同,`awk`中的数组并不...

    linux Shell脚本里面把一个数组传递到awk内部进行处理

    前段时间和几位同事讨论过一个问题:Shell脚本里面怎样把一个数组传递到awk内部进行处理? 当时没有找到方法。前两天在QQ群里讨论awk的时候,无意间又聊起这个话题。机缘巧合之下找到一个思路,特此分享。 测试环境...

    awk详细用法小结awk awk

    awk支持数组和关联数组,允许存储和操作复杂的数据结构。 - **数组**:可以使用下标访问数组元素,下标可以是数字或字符串。 - **关联数组**:使用`in`运算符来判断一个键是否存在于数组中。 #### 七、gawk扩展...

    Effective awk Programming, 4th Edition[awk高效编程4版]

    本书的第四版详细介绍了awk的各个方面,包括语法、内置函数、模式匹配以及高级编程技巧。 书中首先从awk的基础语法开始,解释了如何定义模式和动作,以及如何使用字段分隔符进行数据分割。awk程序通常由模式...

    AWK AWK 详细使用文档

    - **数组类型**:AWK支持两种类型的数组:普通数组和关联数组。普通数组的索引通常是整数,而关联数组可以使用字符串作为索引。 - **数组操作**:可以通过索引来访问和修改数组元素,还可以使用`length()`函数获取...

    The AWK Programming Language 中文版

    AWK中的数组非常实用,可以存储和处理数据集合。此外,用户还可以定义自己的函数,实现程序的模块化。 ### AWK与输入输出 AWK处理输入的方式是基于记录和字段的概念。输入分隔符可以自定义,多行记录的处理可以通过...

    awk+手册中文版.pdf

    awk 概述则介绍了 awk 的定义、特点、优点和应用场景,并解释了 awk 的工作原理和架构。 awk 的优点包括: * 使用直译器(Interpreter),不需先行编译 * 变量无类型之分(Typeless),可使用文字当数组的下标...

    Sed与Awk (中文版)

    awk的脚本语言支持基本的编程结构,如条件判断、循环控制以及数组操作等,这使得awk非常适合处理和分析数据记录。awk的内置函数库也非常丰富,为数据处理提供了便利。 **sed和awk的正则表达式** 由于sed和awk都...

    类Unix系统优秀文本处理工具Awk详细介绍.doc

    《类Unix系统优秀文本处理工具Awk详细介绍》 在类Unix操作系统中,Awk是一种强大的文本分析工具,常被用于处理和分析结构化的文本数据。Awk的名字来源于其三位创造者——Alfred V. Aho、Peter J. Weinberger和Brian...

    GAWK-Effective AWK Programming - GNU Awk编程经典

    接着,书籍转而解决如何使用awk解决问题,其中提到了awk函数库,以及一些实用的awk程序示例,这说明书籍不仅仅是理论的介绍,还包含了实际应用和案例研究。 在“Moving Beyond Standard awk with gawk”部分,作者...

    sed and awk 101 hacks.pdf

    - **引用数组元素、使用循环遍历awk数组、删除数组元素、多维数组、SUBSEP下标分隔符、用asort为数组排序、用asorti为索引排序**:Awk的关联数组是处理文本数据的强大工具,它允许使用任意字符串作为数组的索引。...

    awk set 使用手册

    `set`在`awk`中是一个关键的概念,它涉及到变量、数组以及模式匹配等方面。本手册将深入探讨`awk set`的使用方法,帮助你更好地理解和运用这一工具。 一、`awk`基础 `awk`的名字来源于它的创始人——Alfred V. Aho...

    awk入门到精通.pdf

    它不需要预先编译,具有灵活的变量类型使用、关联数组和内置的管道功能,这些特点都极大地简化了数据处理的复杂度,使得awk在UNIX环境下成为了处理文本的利器。 在学习awk之前,读者需要具备一定的UNIX操作知识,...

Global site tag (gtag.js) - Google Analytics