免费注册 查看新帖 |

Chinaunix

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

咨询各位大侠 一个数据统计的问题 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2005-07-07 16:56 |只看该作者 |倒序浏览
我有2个这样的文件
文件A
37999998062  20                                   7529501.14
37999998111  7                                    7428729.48
37999998129  7                                    5003206.40
37999998137  3                                    1060998.15
37999998145  5                                    4335000.00
37999998153  3                                    1610926.22
文件B
37999997973       10       9616000.00
37999997999       12      28367970.64
37999998062       64      13440000.00
37999998111       14      16810602.98
37999998129        9       3132793.03

现在以这2个文件的第一列为准 如果有相同的 ,如:两个文件都有37999998111
则把对应的第二列相加(7+14=21),第三列相加(7428729.48 +16810602.98=)得出新的一行。只要加起来的结果就行
如何做呢?

论坛徽章:
8
摩羯座
日期:2014-11-26 18:59:452015亚冠之浦和红钻
日期:2015-06-23 19:10:532015亚冠之西悉尼流浪者
日期:2015-08-21 08:40:5815-16赛季CBA联赛之山东
日期:2016-01-31 18:25:0515-16赛季CBA联赛之四川
日期:2016-02-16 16:08:30程序设计版块每日发帖之星
日期:2016-06-29 06:20:002017金鸡报晓
日期:2017-01-10 15:19:5615-16赛季CBA联赛之佛山
日期:2017-02-27 20:41:19
2 [报告]
发表于 2005-07-07 17:22 |只看该作者

咨询各位大侠 一个数据统计的问题

awk 'NR==FNR{a[$1]=$2;b[$1]=$3}
NR>FNR&&a[$1]{print $1,$2+a[$1],$3+b[$1]} '  fileA fileB

论坛徽章:
0
3 [报告]
发表于 2005-07-07 17:46 |只看该作者

咨询各位大侠 一个数据统计的问题

如果 第一列数值不同时在 A文件中 或 B文件中,也要原样输出,如何做呢?

另外能对语句做下大体解释嘛?

论坛徽章:
0
4 [报告]
发表于 2005-07-07 18:13 |只看该作者

咨询各位大侠 一个数据统计的问题

另外 由于第三列数值较大
如何 在对加起来的值如何 用 printf 做下转换 如18.2f 这种 格式的??

论坛徽章:
0
5 [报告]
发表于 2005-07-07 18:35 |只看该作者

咨询各位大侠 一个数据统计的问题

自己再顶一下阿。。。。。。。。。

论坛徽章:
0
6 [报告]
发表于 2005-07-07 19:14 |只看该作者

咨询各位大侠 一个数据统计的问题

有没有人能用sh去做阿?

在数据库中是搞定了,但建表,倒数据,select 方法比较笨些 ,请教各位大侠用shell如何能快速搞定阿 。

论坛徽章:
0
7 [报告]
发表于 2005-07-07 19:15 |只看该作者

咨询各位大侠 一个数据统计的问题

  1. open(DATAA,"data.a") || die ;
  2. open(DATAB,"data.b") || die ;

  3. @dataa=<DATAA>;
  4. @datab=<DATAB>;

  5. close(DATAA);
  6. close(DATAB);

  7. foreach $recb (@datab)
  8. {
  9.         ($idb,$cntb1,$cntb2)=split(' ',$recb);
  10.         $i=0;
  11.         $j=@dataa;
  12.         foreach $reca (@dataa)
  13.         {
  14.                 ($ida,$cnta1,$cnta2)=split(' ',$reca);
  15.                 if($ida==$idb)
  16.                 {
  17.                         $cnta1+=$cntb1;
  18.                         $cnta2+=$cntb2;
  19.                         $dataa[$i]=join(' ',$ida,$cnta1,$cnta2);
  20.                         last;
  21.                 }
  22.                 else
  23.                 {
  24.                         $i++;
  25.                 }
  26.         }
  27.         if($i==$j)
  28.         {
  29.                 $dataa[$i]=join(' ',$idb,$cntb1,$cntb2);
  30.         }
  31. }

  32. foreach $rec (@dataa)
  33. {
  34.         ($id,$cnt1,$cnt2)=split(' ',$rec);
  35.         printf(":%s:%d:%12.2f:\n",$id,$cnt1,$cnt2);
  36. }
复制代码

论坛徽章:
0
8 [报告]
发表于 2005-07-07 19:28 |只看该作者

咨询各位大侠 一个数据统计的问题

  1. cat data.a data.b|awk '{a[$1]+=$2;b[$1]+=$3}END{for(i in a) printf "%s %d %18.2f\n",i,a[i],b[i]}'
复制代码

论坛徽章:
0
9 [报告]
发表于 2005-07-07 19:30 |只看该作者

咨询各位大侠 一个数据统计的问题

郁闷,perl到底有没有必要搞了?!感觉太繁琐了!

论坛徽章:
0
10 [报告]
发表于 2005-07-08 08:13 |只看该作者

咨询各位大侠 一个数据统计的问题

谢谢! 我先试试 阿
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP