欢迎来到天天文库
浏览记录
ID:8811193
大小:411.00 KB
页数:8页
时间:2018-04-08
《awk数组排序多种实现方法》由会员上传分享,免费在线阅读,更多相关内容在应用文档-天天文库。
1、[chengmo@localhost~]$awk'BEGIN{info="thisisatest";slen=split(info,tA,"");for(i=1;i<=slen;i++){printi,tA[i];}}' 1this2is3a4test 一、通过内置函数(asort,asorti使用)awk3.1以上版本才支持 asort使用说明srcarrlen=asort[srcarr,dscarr]默认返回值是:原数组长度,传入参数dscarr则将排序后数组赋值给dscarr. [chengm
2、o@localhost~]$awk'BEGIN{a[100]=100;a[2]=224;a[3]=34;slen=asort(a,tA);for(i=1;i<=slen;i++){printi,tA[i];}}'13421003224 asort只对值进行了排序,因此丢掉原先键值。 2、asorti使用说明 [chengmo@localhost~]$awk'BEGIN{a["d"]=100;a["a"]=224;a["c"]=34;slen=asorti(a,tA);for(i=1;i<=slen;i++
3、){printi,tA[i],a[tA[i]];}}'1a2242c343d100 asorti对键值进行排序(字符串类型),将生成新的数组放入:tA中。 二、通过管道发送到sort排序 [chengmo@localhost~]$awk'BEGIN{a[100]=100;a[2]=224;a[3]=34;for(iina){printi,a[i]
4、"sort-r-n-k2";}}'2224100100334 通过管道,发送到外部程序“sort”排序,-r从大到小,-n按照数字排序,-k2以第2列排序。通过
5、将数据丢给第3方的sort命令,所有问题变得非常简单。如果以key值排序–k2变成-k1即可。 [chengmo@localhost~]$awk'BEGIN{a[100]=100;a[2]=224;a[3]=34;for(iina){printi,a[i]
6、"sort-r-n-k1";}}'1001003342224 三、自定义排序函数 awk自定义函数结构:functionfunname(p1,p2,p3) { staction; returnvalue; } 以上是:awk自定义函数表示方式,
7、默认传入参数都是以引用方式传入,return值,只能是字符型或者数值型。不能返回数组类型。如果返回数组类型。需要通过形参方式传入。再获得。 awk返回数组类型 awk'functiontest(ary){ for(i=0;i<10;i++){ ary[i]=i; } returni;}BEGIN{ n=test(array); for(i=0;i8、排序2按照字符串排序 #tarr排序返回的数组 #splitseq分割字符串数组中键与值之间分割字符串 #return数组长度 #实现思路,将原始数组a[‘a’]=100排序后变成a[1]=a分隔符100,然后按照下标递归显示内容。本排序使用冒泡方式进行。 functionsortArr(arr,key,datatype,tarr,splitseq){ if(key~/[^1-2]/) {returntarr;} for(kinarr) { tarr[++alen]=(k""split9、seq""arr[k]); } for(m=1;m<=alen;m++) { for(n=1;n<=alen-m-1;n++) { split(tarr[m],tm,splitseq); split(tarr[n+1],tn,splitseq); tnum=tarr[m]; if(datatype==1) { if(tm[key]+010、r[n+1]; tarr[n+1]=tnum; } } else { if((tm[key]"")<(tn[key]"")) { tarr[m]=tarr[n+1]; tarr[n+1]=tnum; } } } } returnalen;} 完整代码如下: [
8、排序2按照字符串排序 #tarr排序返回的数组 #splitseq分割字符串数组中键与值之间分割字符串 #return数组长度 #实现思路,将原始数组a[‘a’]=100排序后变成a[1]=a分隔符100,然后按照下标递归显示内容。本排序使用冒泡方式进行。 functionsortArr(arr,key,datatype,tarr,splitseq){ if(key~/[^1-2]/) {returntarr;} for(kinarr) { tarr[++alen]=(k""split
9、seq""arr[k]); } for(m=1;m<=alen;m++) { for(n=1;n<=alen-m-1;n++) { split(tarr[m],tm,splitseq); split(tarr[n+1],tn,splitseq); tnum=tarr[m]; if(datatype==1) { if(tm[key]+010、r[n+1]; tarr[n+1]=tnum; } } else { if((tm[key]"")<(tn[key]"")) { tarr[m]=tarr[n+1]; tarr[n+1]=tnum; } } } } returnalen;} 完整代码如下: [
10、r[n+1]; tarr[n+1]=tnum; } } else { if((tm[key]"")<(tn[key]"")) { tarr[m]=tarr[n+1]; tarr[n+1]=tnum; } } } } returnalen;} 完整代码如下: [
此文档下载收益归作者所有