$ echo "aaa 3 1-2-3-4-5" | awk '{n=split($3,a,"-")for(i=1i<=ni++)print $1,$2,a[i]}'aaa 3 1aaa 3 2aaa 3 3aaa 3 4aaa 3 5
向数组里添加一个元素怎么添加,这儿总结有三种方法:1、一般数组是不能添加元素的,因为他们在初始化时就已定好长度了,不能改变长度。
但有个可以改变大小的数组为ArrayList,即可以定义一个ArrayList数组,然后用add(element)方法往里添加元素即可,还可add(index,element)往指定下标处添加元素
2、思路为先把array转化为list,用list的add()方法添加元素,再把list转化为array。
但这儿会有一个陷阱盲区,在把array转化为list的过程中,使用的asList()方法会返回一个final的,固定长度的ArrayList类,并不是java.util.ArrayList,直接这样利用它进行add()或remove()是无效的。
那应该怎么做呢,在定义list的时候就直接对array进行转化
第三个方法思路为创建一个新数组,新数组的大小为旧数组大小+1,把旧数组里的元素copy一份进新数组,并把要添加的元素添加进新数组即可。
awk的数组其实很好理解。一般编程语言的数组,其下标只能是数字,比如a[3],表示数组a的第四个元素。但是awk的不同,其下标可以是任意字符或者字符串。比如a[bob],表示数组a的一个元素,它的下标是"bob"。
比如有个文本文件alex.txt:
a 1
b 2
c 3
a 4
b 5
a 6
如果我们想统计以a开头的行后面的数字之和,就是“1+4+6”,我们用awk怎么做呢:
cat alex.txt | awk ‘{if(!array[$1]) {array[$1]=$2}
elae{arrary[$1]=array[$1]+$2}}END{print array[a]}’
命令中有个数组array,当读取alex.txt第一行时,$1是“a”,array[a]刚开始是“”(空字符串),所以!array[a]就为真,那么array[a]=1,数组array就有了第一个元素array[a].
同理,读取第二行之后结果array[a]=1, array[b]=2,数组array就有了2个元素。
第三行之后结果是array[a]=1, array[b]=2, array[c]=3,数组array就有了3个元素。
第四行之后结果是array[a]=5(1+4,4为第四行的$2), array[b]=2, array[c]=3
第五行之后结果是array[a]=5, array[b]=7, array[c]=3
第六行之后结果是array[a]=11, array[b]=7, array[c]=3
END的意思是读取完文件所有行后执行的语句,打印出数组第一个元素array[a].
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)