免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 1705 | 回复: 1
打印 上一主题 下一主题

[文本处理] 关于求一列数的中位数 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2018-04-06 15:53 |只看该作者 |倒序浏览
试着用http://bbs.chinaunix.net/thread-4216239-1-1.html这个帖子里8楼的代码,如果一列数是整数的话可以,但是我由一列数是小数:
100.223665
100.352905
100.198633
100.296956

用了上面的代码awk 'function w(v){l=asort(a,t);if(l%2){print v,t[int(l/2)+1]}else{print v,(t[int(l/2)+1]+t[int(l/2)])/2};delete a}FNR==1{if(f)w(f);f=FILENAME}{a[FNR]=$2}END{w(f)}' test.txt
中位数应该是100.2603105,但是显示的确是100.26,请问应该如何改,谢谢!

论坛徽章:
25
程序设计版块每日发帖之星
日期:2016-05-03 06:20:0015-16赛季CBA联赛之八一
日期:2018-07-05 10:34:09黑曼巴
日期:2018-07-06 15:19:5015-16赛季CBA联赛之佛山
日期:2018-08-03 13:19:3315-16赛季CBA联赛之山西
日期:2018-08-07 19:46:2315-16赛季CBA联赛之广夏
日期:2018-08-08 19:31:5015-16赛季CBA联赛之青岛
日期:2018-11-26 15:21:5015-16赛季CBA联赛之上海
日期:2018-12-11 09:45:3219周年集字徽章-年
日期:2020-04-18 23:54:5215-16赛季CBA联赛之深圳
日期:2020-04-19 21:40:19黑曼巴
日期:2022-04-03 17:55:1315-16赛季CBA联赛之八一
日期:2018-07-03 16:56:46
2 [报告]
发表于 2018-04-06 19:52 |只看该作者
本帖最后由 wh7211 于 2018-04-06 21:00 编辑

回复 1# ilovefushun


  1. cat 1
  2. a 100.223665
  3. b 100.352905
  4. c 100.198633
  5. d 100.296956

  6. cat 2
  7. e 1
  8. f 3
  9. g 9
  10. h 8
  11. i 5
复制代码


<<<awk4.0以下版本
  1. awk 'function w(v){l=asort(a,t);if(l%2){printf("%s %d\n",v,t[int(l/2)+1])}else{printf("%s %.7f\n",v,(t[int(l/2)+1]+t[int(l/2)])/2)};delete a}FNR==1{if(f)w(f);f=FILENAME}{a[FNR]=$2}END{w(f)}' 1 2
  2. 1 100.2603105
  3. 2 5
复制代码


<<<awk4.0+
  1. awk '{a[FILENAME][FNR]=$2}END{for(i in a){c=asort(a[i],b);d=int(c/2);if(c%2==0){printf("%s %.7f\n",i,(b[d]+b[d+1])/2)}else{printf("%s %d\n",i,b[d+1])}}}' 1 2
  2. 1 100.2603105
  3. 2 5
复制代码
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP