亚洲av成人无遮挡网站在线观看,少妇性bbb搡bbb爽爽爽,亚洲av日韩精品久久久久久,兔费看少妇性l交大片免费,无码少妇一区二区三区

  免費注冊 查看新帖 |

Chinaunix

  平臺 論壇 博客 文庫
最近訪問板塊 發(fā)新帖
查看: 4547 | 回復(fù): 9
打印 上一主題 下一主題

[文本處理] awk 列相同合并行 [復(fù)制鏈接]

論壇徽章:
0
跳轉(zhuǎn)到指定樓層
1 [收藏(0)] [報告]
發(fā)表于 2012-08-10 14:29 |只看該作者 |倒序瀏覽
如果第一列到第四列都相同,就合并行
ECR01;2012-5-10;2012-5-10 00:00:00;ISL-2;448
ECR01;2012-5-10;2012-5-10 00:00:00;ISL-2;0
ECR01;2012-5-10;2012-5-10 00:00:00;ISL-2;0
ECR01;2012-5-10;2012-5-10 00:00:00;ISL-2;0
ECR01;2012-5-10;2012-5-10 00:00:00;ISL-2;0
ECR01;2012-5-10;2012-5-10 00:00:00;ISL-2;0
ECR01;2012-5-10;2012-5-10 00:00:00;ISL-2;0
ECR01;2012-5-10;2012-5-10 00:00:00;ISL-2;1
ECR01;2012-5-10;2012-5-10 00:00:00;ISL-1;448
ECR01;2012-5-10;2012-5-10 00:00:00;ISL-1;0
ECR01;2012-5-10;2012-5-10 00:00:00;ISL-1;0
ECR01;2012-5-10;2012-5-10 00:00:00;ISL-1;0
ECR01;2012-5-10;2012-5-10 00:00:00;ISL-1;0
ECR01;2012-5-10;2012-5-10 00:00:00;ISL-1;0
ECR01;2012-5-10;2012-5-10 00:00:00;ISL-1;2
ECR01;2012-5-10;2012-5-10 00:00:00;ISL-1;0
需要的結(jié)果
ECR01;2012-5-10;2012-5-10 00:00:00;ISL-2;448;0;0;0;0;0;0;1
ECR01;2012-5-10;2012-5-10 00:00:00;ISL-1;448;0;0;0;0;0;2;0
參照曾經(jīng)的一個帖子,依葫蘆畫瓢如下(但是不成功),請各位指教
awk '{a[$1";"$2";"$3";"$4]=a[$1";"$2";"$3";"$4](a[$1";"$2";"$3";"$4]?";":"")$5}END{for (j in a) print j,a[j]}'
ECR01;2012-5-10;2012-5-10;00:00:00;ISL-2;1;;
ECR01;2012-5-10;2012-5-10;00:00:00;ISL-1;2;;
ECR01;2012-5-10;2012-5-10;00:00:00;ISL-2;0;;
ECR01;2012-5-10;2012-5-10;00:00:00;ISL-2;448;;
ECR01;2012-5-10;2012-5-10;00:00:00;ISL-1;0;;
ECR01;2012-5-10;2012-5-10;00:00:00;ISL-1;448;;

論壇徽章:
0
2 [報告]
發(fā)表于 2012-08-10 14:33 |只看該作者
awk  'BEGIN{OFS=FS=";"}{split(a[$1";"$2";"$3";"$4],temp);$5=temp[5]";"$5;a[$1";"$2";"$3";"$4]=$0}END{for(n in a)print a[n]}'
這個嘗試了也不行
ECR01;2012-5-10;2012-5-10 00:00:00;ISL-1;;0
ECR01;2012-5-10;2012-5-10 00:00:00;ISL-2;;1

論壇徽章:
0
3 [報告]
發(fā)表于 2012-08-10 14:46 |只看該作者
本帖最后由 personball 于 2012-08-10 14:49 編輯

回復(fù) 1# conall


    awk -F; '{t=$1";"$2";"$3";"$4;a[t]=a[t]";"$NF;}END{for( i in a)print a[ i ]}'

大致思路,代碼未測試
PS:最近[ i ]標(biāo)簽很活躍,囧,總是斜體

論壇徽章:
0
4 [報告]
發(fā)表于 2012-08-10 14:54 |只看該作者
本帖最后由 conall 于 2012-08-10 15:01 編輯

謝謝,但是不是我想要的結(jié)果
$ awk -F";" '{t=$1";"$2";"$3";"$4;a[t]=a[t]";"$NF;}END{for( i in a)print a[ i ]}' 1.txt
;448;0;0;0;0;0;2;0
;448;0;0;0;0;0;0;1
修正了一下,
$ awk -F";" '{t=$1";"$2";"$3";"$4;a[t]=a[t]";"$NF;b=$0;}END{for( i in a)print b,a[ i ]}' 1.txt
ECR01;2012-5-10;2012-5-10 00:00:00;ISL-1;0 ;448;0;0;0;0;0;2;0
ECR01;2012-5-10;2012-5-10 00:00:00;ISL-1;0 ;448;0;0;0;0;0;0;1
還是不行,結(jié)果應(yīng)該是
ECR01;2012-5-10;2012-5-10 00:00:00;ISL-2;448;0;0;0;0;0;0;1
ECR01;2012-5-10;2012-5-10 00:00:00;ISL-1;448;0;0;0;0;0;2;0
再請賜教

論壇徽章:
10
天蝎座
日期:2013-09-22 22:32:23程序設(shè)計版塊每日發(fā)帖之星
日期:2016-08-07 06:20:00lufei
日期:2016-06-17 17:38:40程序設(shè)計版塊每日發(fā)帖之星
日期:2016-06-12 06:20:002016科比退役紀(jì)念章
日期:2016-05-31 15:47:20CU十四周年紀(jì)念徽章
日期:2016-05-27 12:24:562015年亞洲杯之阿曼
日期:2015-05-03 21:01:352015年辭舊歲徽章
日期:2015-03-03 16:54:15天蝎座
日期:2013-10-20 21:05:24程序設(shè)計版塊每日發(fā)帖之星
日期:2016-08-11 06:20:00
5 [報告]
發(fā)表于 2012-08-10 14:59 |只看該作者
  1. awk -F";" '{a=$1";"$2";"$3";"$4; out[a]=out[a]";"$NF}END{for (i in out)print i out[i]}'
復(fù)制代碼

論壇徽章:
0
6 [報告]
發(fā)表于 2012-08-10 15:07 |只看該作者
本帖最后由 conall 于 2012-08-10 15:10 編輯

謝謝,
awk -F";" '{a=$1";"$2";"$3";"$4; out[a]=out[a]";"$NF}END{for (i in out)print i out}'
是可以的,但是對比“personball ”的
awk -F";" '{t=$1";"$2";"$3";"$4;a[t]=a[t]";"$NF;}END{for( i in a)print a[ i ]}'
稍微修正一下
awk -F";" '{t=$1";"$2";"$3";"$4;a[t]=a[t]";"$NF;}END{for( i in a)print i a[ i ]}'也是可行的
1.這里,
awk -F";" '{t=$1";"$2";"$3";"$4;a[t]=a[t]";"$NF;}END{for( i in a)print i a[ i ]}'
awk -F";" '{a=$1";"$2";"$3";"$4; out[a]=out[a]";"$NF}END{for (i in out)print i out}'
都可以執(zhí)行成功,但是";"$NF;}END與";"$NF}END有什么區(qū)別?
2.print i a[ i ]其中i是等同于$0嗎?

論壇徽章:
10
天蝎座
日期:2013-09-22 22:32:23程序設(shè)計版塊每日發(fā)帖之星
日期:2016-08-07 06:20:00lufei
日期:2016-06-17 17:38:40程序設(shè)計版塊每日發(fā)帖之星
日期:2016-06-12 06:20:002016科比退役紀(jì)念章
日期:2016-05-31 15:47:20CU十四周年紀(jì)念徽章
日期:2016-05-27 12:24:562015年亞洲杯之阿曼
日期:2015-05-03 21:01:352015年辭舊歲徽章
日期:2015-03-03 16:54:15天蝎座
日期:2013-10-20 21:05:24程序設(shè)計版塊每日發(fā)帖之星
日期:2016-08-11 06:20:00
7 [報告]
發(fā)表于 2012-08-10 15:13 |只看該作者
";"$NF;}END與";"$NF}END
沒區(qū)別

print i a[ i ] i 是數(shù)組a的索引值,可以把a看作關(guān)聯(lián)數(shù)組.

論壇徽章:
0
8 [報告]
發(fā)表于 2012-08-10 15:49 |只看該作者
本帖最后由 personball 于 2012-08-10 15:53 編輯

回復(fù) 4# conall


    哈,不好意思,因為自己沒測試過,漏了輸出前面部分了  print i a[ i ] 才對。。。
稍微解釋一下,awk中 a[t] 就是以t的值(前4列)做下標(biāo)的數(shù)組變量,該變量本身對最后一列進行字符串累加,最后遍歷數(shù)組,輸出下標(biāo)i 即前4列,和值a[ i ] 即可

論壇徽章:
0
9 [報告]
發(fā)表于 2012-08-10 15:53 |只看該作者
謝謝前輩解答!

論壇徽章:
1
天蝎座
日期:2013-08-22 15:14:44
10 [報告]
發(fā)表于 2012-08-10 22:24 |只看該作者
本帖最后由 guogang225 于 2012-08-10 22:26 編輯

awk -F";" '{t=$1FS$2FS$3FS$4;a[t]=a[t]FS$5}END{for(i in a) print i a}' awk.txt
您需要登錄后才可以回帖 登錄 | 注冊

本版積分規(guī)則 發(fā)表回復(fù)

  

北京盛拓優(yōu)訊信息技術(shù)有限公司. 版權(quán)所有 京ICP備16024965號-6 北京市公安局海淀分局網(wǎng)監(jiān)中心備案編號:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年舉報專區(qū)
中國互聯(lián)網(wǎng)協(xié)會會員  聯(lián)系我們:huangweiwei@itpub.net
感謝所有關(guān)心和支持過ChinaUnix的朋友們 轉(zhuǎn)載本站內(nèi)容請注明原作者名及出處

清除 Cookies - ChinaUnix - Archiver - WAP - TOP