awk数组排序多种实现方法

awk数组排序多种实现方法

ID:8973082

大小:411.00 KB

页数:8页

时间:2018-04-13

awk数组排序多种实现方法_第1页
awk数组排序多种实现方法_第2页
awk数组排序多种实现方法_第3页
awk数组排序多种实现方法_第4页
awk数组排序多种实现方法_第5页
资源描述:

《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. [chengmo@localhost~]$awk'BEGIN{a[100]=100;a[2]=224;

2、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++){printi,tA[i],a[tA[i]];}}'1a2242c343d100 asorti对键值进行排序(字符串类型),将生成新的数组放入:tA中。 二、通过管道发送到s

3、ort排序 [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列排序。通过将数据丢给第3方的sort命令,所有问题变得非常简单。如果以key值排序–k2变成-k1即可。 [chengmo@localhost~]$awk'BEGIN{a[100]=100;a[2]=224;a[3]=34;for(iina){printi,a[i]

5、"so

6、rt-r-n-k1";}}'1001003342224 三、自定义排序函数 awk自定义函数结构:functionfunname(p1,p2,p3) {   staction;   returnvalue; } 以上是:awk自定义函数表示方式,默认传入参数都是以引用方式传入,return值,只能是字符型或者数值型。不能返回数组类型。如果返回数组类型。需要通过形参方式传入。再获得。 awk返回数组类型 awk'functiontest(ary){ for(i=0;i<10;i++){ ary[i]=i; } returni;}BEGIN{ n=test(array); for(i=0;i

7、;i++){ printarray[i]; }}'排序函数#arr传入一维数组 #key排序类型1是按照值排序2按照键值 #datatype比较类型1按照数字排序2按照字符串排序 #tarr排序返回的数组 #splitseq分割字符串数组中键与值之间分割字符串 #return数组长度 #实现思路,将原始数组a[‘a’]=100排序后变成a[1]=a分隔符100,然后按照下标递归显示内容。本排序使用冒泡方式进行。   functionsortArr(arr,key,datatype,tarr,splitseq){   if(key~/[^1-2]/)   {returntarr;}  for(

8、kinarr)  {   tarr[++alen]=(k""splitseq""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]+0

9、         tarr[n+1]=tnum;        }      }      else      {        if((tm[key]"")<(tn[key]""))        {           tarr[m]=tarr[n+1];           tarr[n+1]=tnum;        }      }    }  }  returnalen;}   完整代码如下: [

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。