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

  免費注冊 查看新帖 |

Chinaunix

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

awk 數(shù)組問題 [復制鏈接]

論壇徽章:
0
跳轉(zhuǎn)到指定樓層
1 [收藏(0)] [報告]
發(fā)表于 2011-11-23 17:26 |只看該作者 |倒序瀏覽
原始數(shù)據(jù):

2011:11:04 00:25:00|2011:11:04 00:30:00|0801|3501|notifyDeliveryReceipt|26|27|27|0||4349
2011:11:04 00:25:00|2011:11:04 00:30:00|2001|3501|notifyDeliveryReceipt|26|30|30|0||4579
2011:11:04 00:25:00|2011:11:04 00:30:00|3501|0701|send|26|13|12|1||1920
2011:11:04 00:25:00|2011:11:04 00:30:00|3501|1301|send|26|5|5|0||838
2011:11:04 00:25:00|2011:11:04 00:30:00|3101|3501|notifyDelivery|27|5|5|0||785
2011:11:04 00:25:00|2011:11:04 00:30:00|2500|3501|notifyDelivery|27|4|4|0||608
2011:11:05 00:25:00|2011:11:05 00:30:00|3501|2300|send|26|9|9|0||1871
2011:11:05 00:25:00|2011:11:05 00:30:00|3501|0600|send|26|2|2|0||388
2011:11:05 00:25:00|2011:11:05 00:30:00|3501|1200|send|26|11|11|0||303
2011:11:05 00:25:00|2011:11:05 00:30:00|3501|2800|DeliveryConfirm|29|3|3|0||3385
2011:11:05 00:25:00|2011:11:05 00:30:00|3501|0801|DeliveryConfirm|29|15|15|0||4275

希望得到:
2011:11:04 notifyDeliveryReceipt 26 57 100%
2011:11:04 send 26 18 92.13%
2011:11:04 notifyDelivery 27 9 100%
2011:11:05 send 22 100%
2011:11:05 DeliveryConfirm 29 18 100%

以awk -F '[| ]' 分割,第1域是日期  第7域是動作 第8域是動作類型 第9域是總數(shù) 第10域是成功數(shù) 第11域是失敗數(shù)

希望根據(jù) 日期 動作及動作類型的不同計算出相應的成功率。 成功率是 第10域除以第9域。

請盡量以 awk 數(shù)組方式解決這個問題

論壇徽章:
0
2 [報告]
發(fā)表于 2011-11-23 17:30 |只看該作者
沒看懂阿!怎么第十域總是空阿

論壇徽章:
15
2015年辭舊歲徽章
日期:2015-03-03 16:54:15雙魚座
日期:2015-01-15 17:29:44午馬
日期:2015-01-06 17:06:51子鼠
日期:2014-11-24 10:11:13寅虎
日期:2014-08-18 07:10:55酉雞
日期:2014-04-02 12:24:51雙子座
日期:2014-04-02 12:19:44天秤座
日期:2014-03-17 11:43:36亥豬
日期:2014-03-13 08:13:51未羊
日期:2014-03-11 12:42:03白羊座
日期:2013-11-20 10:15:18CU大;照
日期:2013-04-17 11:48:45
3 [報告]
發(fā)表于 2011-11-23 19:11 |只看該作者
本帖最后由 rdcwayx 于 2011-11-23 19:13 編輯
  1. awk -F \| '{ split($1,a," ");
  2.                  date[a[1]];act[$5 OFS $6];
  3.                  Total[a[1] OFS $5 OFS $6]+=$7;Suc[a[1] OFS $5 OFS $6]+=$8}
  4.                END{for (i in date)
  5.                            for (j in act) if (Total[i OFS j]!=0) printf "%s %s %s %.2f%\n", i,j,Total[i OFS j],Suc[i OFS j]*100/Total[i OFS j]
  6.                      } ' infile

  7. 2011:11:04 send 26 18 94.44%
  8. 2011:11:04 notifyDelivery 27 9 100.00%
  9. 2011:11:04 notifyDeliveryReceipt 26 57 100.00%
  10. 2011:11:05 send 26 22 100.00%
  11. 2011:11:05 DeliveryConfirm 29 18 100.00%

復制代碼

論壇徽章:
33
ChinaUnix元老
日期:2015-02-02 08:55:39CU十四周年紀念徽章
日期:2019-08-20 08:30:3720周年集字徽章-周	
日期:2020-10-28 14:13:3020周年集字徽章-20	
日期:2020-10-28 14:04:3019周年集字徽章-CU
日期:2019-09-08 23:26:2519周年集字徽章-19
日期:2019-08-27 13:31:262016科比退役紀念章
日期:2022-04-24 14:33:24
4 [報告]
發(fā)表于 2011-11-23 21:19 |只看該作者
回復 2# vnb2018


你數(shù)錯了,豎線和空格都是列分隔符。

論壇徽章:
0
5 [報告]
發(fā)表于 2011-11-24 09:31 |只看該作者
rdcwayx 發(fā)表于 2011-11-23 19:11



    謝謝,理解了。

我用以前的方法加上你的思路,寫成了這樣 :

awk -F '[| ]' '{perc[$1 OFS $7 OFS $8]=100*(sum1[$1 OFS $7 OFS $8]+=$10)/(sum2[$1 OFS $7 OFS $8]+=$9)}END{for(i in perc)printf "%s|%s|%0.2f%\n", i,sum2,perc}'   

雖然不如你的已經(jīng)排序,但我看來好像這個更簡單,請幫忙一起看看是否還有改進的地方

論壇徽章:
15
2015年辭舊歲徽章
日期:2015-03-03 16:54:15雙魚座
日期:2015-01-15 17:29:44午馬
日期:2015-01-06 17:06:51子鼠
日期:2014-11-24 10:11:13寅虎
日期:2014-08-18 07:10:55酉雞
日期:2014-04-02 12:24:51雙子座
日期:2014-04-02 12:19:44天秤座
日期:2014-03-17 11:43:36亥豬
日期:2014-03-13 08:13:51未羊
日期:2014-03-11 12:42:03白羊座
日期:2013-11-20 10:15:18CU大;照
日期:2013-04-17 11:48:45
6 [報告]
發(fā)表于 2011-11-24 09:56 |只看該作者
本帖最后由 rdcwayx 于 2011-11-24 10:08 編輯

可能開始的時候我想復雜了。
  1. awk -F '[| ]' '{str=$1 OFS $7 OFS $8; sum1[str]+=$10;sum2[str]+=$9;}
  2.     END{for(i in sum1) printf "%s|%s|%0.2f%\n", i,sum2[i],sum1[i]*100/sum2[i]}'  OFS=\| infile |sort -n

  3. 2011:11:04|notifyDeliveryReceipt|26|57|100.00%
  4. 2011:11:04|notifyDelivery|27|9|100.00%
  5. 2011:11:04|send|26|18|94.44%
  6. 2011:11:05|DeliveryConfirm|29|18|100.00%
  7. 2011:11:05|send|26|22|100.00%

復制代碼
您需要登錄后才可以回帖 登錄 | 注冊

本版積分規(guī)則 發(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