免费注册 查看新帖 |

Chinaunix

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

有三列数组,把2,3列变成行,同时保持第一列唯一 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2015-05-06 03:37 |只看该作者 |倒序浏览
本人有下面的一组数据,根据第一列的值,将第二,三列变成行,先谢谢各位的帮助。

PL -0.00 5.50
PL -0.25 3.50
PL -0.50 0.00
PL -0.75 4.50
-0.25 -0.00 1.00
-0.25 -0.25 4.50
-0.25 -0.50 1.00
-0.75 -0.75 1.00
-0.75 -1.00 0.00
-1.00 -0.25 3.50
-1.00 -0.50 0.00
-1.00 -1.25 3.40
-1.00 -1.75 4.00

结果如下:

PL,-0.00,-0.25,-0.50,-0.75
PL,5.50,3.50,0.00,4.50
-0.25,-0.00,-0.25,-0.50
-0.25,1.00,4.50,1.00
-0.75,-0.75,-1.00
-0.75,1.00,0.00
-1.00,-0.25,-0.50,-1.25 ,-1.75
-1.00,3.50,0.00,3.40,4.00


论坛徽章:
7
巳蛇
日期:2013-11-28 09:22:59天秤座
日期:2014-10-25 15:40:452015年辞旧岁徽章
日期:2015-03-03 16:54:152015年迎新春徽章
日期:2015-03-04 09:53:172015亚冠之德黑兰石油
日期:2015-07-15 08:46:452015亚冠之平阳省
日期:2015-11-08 16:27:53白银圣斗士
日期:2015-11-14 09:58:12
2 [报告]
发表于 2015-05-06 10:25 |只看该作者
献个拙!
  1. #!/usr/bin/perl
  2. use strict;

  3. my ($data,@ids)=({},());
  4. while (<DATA>){
  5.         chomp;
  6.         my ($id,$a,$b)=split;
  7.         if ($data->{$id}){
  8.                 $data->{$id}->[0].=",$a";
  9.                 $data->{$id}->[1].=",$b";
  10.         }else{
  11.                 push @ids,$id;
  12.                 $data->{$id}=[$a,$b];
  13.         }
  14. }
  15. for(@ids){
  16.         print "$_,$data->{$_}->[0]\n$_,$data->{$_}->[1]\n"
  17. }

  18. __DATA__
  19. PL -0.00 5.50
  20. PL -0.25 3.50
  21. PL -0.50 0.00
  22. PL -0.75 4.50
  23. -0.25 -0.00 1.00
  24. -0.25 -0.25 4.50
  25. -0.25 -0.50 1.00
  26. -0.75 -0.75 1.00
  27. -0.75 -1.00 0.00
  28. -1.00 -0.25 3.50
  29. -1.00 -0.50 0.00
  30. -1.00 -1.25 3.40
  31. -1.00 -1.75 4.00
复制代码

论坛徽章:
7
戌狗
日期:2013-12-15 20:43:38技术图书徽章
日期:2014-03-05 01:33:12技术图书徽章
日期:2014-03-15 20:31:17未羊
日期:2014-03-25 23:48:20丑牛
日期:2014-04-07 22:37:44巳蛇
日期:2014-04-11 21:58:0915-16赛季CBA联赛之青岛
日期:2016-03-17 20:36:13
3 [报告]
发表于 2015-05-07 01:00 |只看该作者
shishi
  1. my @A;
  2. my $C = '\(^oo^)/';

  3. while (<DATA>) {
  4.     my ( $c, @cs, $i ) = split;
  5.     if ( $c ne $C ) {
  6.         push @A, [ ($c) x @cs ];
  7.         $C = $c;
  8.     }
  9.     $A[-1][ $i++ ] .= ", $_" for @cs;
  10. }

  11. say for map @$_, @A;

  12. __DATA__
  13. PL -0.00 5.50
  14. PL -0.25 3.50
  15. PL -0.50 0.00
  16. PL -0.75 4.50
  17. -0.25 -0.00 1.00
  18. -0.25 -0.25 4.50
  19. -0.25 -0.50 1.00
  20. -0.75 -0.75 1.00
  21. -0.75 -1.00 0.00
  22. -1.00 -0.25 3.50
  23. -1.00 -0.50 0.00
  24. -1.00 -1.25 3.40
  25. -1.00 -1.75 4.00
复制代码

论坛徽章:
0
4 [报告]
发表于 2015-05-11 10:17 |只看该作者
回复 2# b114213903


    谢谢b114213903, 结果正是我要的。

论坛徽章:
0
5 [报告]
发表于 2015-05-11 11:19 |只看该作者
回复 3# rubyish


    谢谢rubyish,我的perl是v5.8.8, 没有say, 单位的机子,没有root权限去升级及下载,只能用现有的。



@n= map "@$_", @A;
print "@n\n";

代替say for map @$_, @A; 得不到我要的结果。 继续试验中。

论坛徽章:
0
6 [报告]
发表于 2015-05-11 11:35 |只看该作者
say for ...
大约是这样子的一回事
print "$_\n" for ...

论坛徽章:
0
7 [报告]
发表于 2015-05-12 02:36 |只看该作者
回复 6# ba_du_co

是这样吗:  print "$_\n" for map @$_, @A;

结果多了回车:

PL, -0.00
, -0.25
, -0.50
, -0.75

PL, 5.50
, 3.50
, 0.00
, 4.50

...
  
-1.50, -0.00
, -0.25

-1.50, 1.00
, 1.50

论坛徽章:
60
20周年集字徽章-20	
日期:2020-10-28 14:04:3015-16赛季CBA联赛之北京
日期:2016-07-06 15:42:0715-16赛季CBA联赛之同曦
日期:2016-06-12 10:38:0915-16赛季CBA联赛之佛山
日期:2016-05-27 11:54:56黄金圣斗士
日期:2015-12-02 11:44:35白银圣斗士
日期:2015-11-25 14:32:43白银圣斗士
日期:2015-11-23 12:53:352015亚冠之布里斯班狮吼
日期:2015-10-21 16:55:482015亚冠之首尔
日期:2015-09-01 16:46:052015亚冠之德黑兰石油
日期:2015-08-31 11:39:192015亚冠之萨济拖拉机
日期:2015-08-28 21:06:5315-16赛季CBA联赛之广东
日期:2016-07-12 14:58:53
8 [报告]
发表于 2015-05-18 16:30 |只看该作者
  1. awk '{ if(!x[$1]++)m[++n]=$1;for(i=2;i<=NF;i++) a[$1][i]=length(a[$1][i])?a[$1][i]","$i:$i }END{for(i=1;i<=n;i++)for(j=2;j<=NF;j++)print m[i]","a[m[i]][j]}' inputfile
复制代码

论坛徽章:
307
程序设计版块每周发帖之星
日期:2016-04-08 00:41:33操作系统版块每日发帖之星
日期:2015-09-02 06:20:00每日论坛发贴之星
日期:2015-09-02 06:20:00程序设计版块每日发帖之星
日期:2015-09-04 06:20:00每日论坛发贴之星
日期:2015-09-04 06:20:00每周论坛发贴之星
日期:2015-09-06 22:22:00程序设计版块每日发帖之星
日期:2015-09-09 06:20:00程序设计版块每日发帖之星
日期:2015-09-19 06:20:00程序设计版块每日发帖之星
日期:2015-09-20 06:20:00每日论坛发贴之星
日期:2015-09-20 06:20:00程序设计版块每日发帖之星
日期:2015-09-22 06:20:00程序设计版块每日发帖之星
日期:2015-09-24 06:20:00
9 [报告]
发表于 2016-09-21 12:10 |只看该作者
  1. #!/usr/bin/perl
  2. use strict;
  3. use warnings;

  4. my @aData;
  5. while (<DATA>){
  6.     my @aList = split;
  7.     if (!@aData or $aData[-1][0] ne $aList[0]){
  8.         push (@aData, [$aList[0], [$aList[1]], [$aList[-1]]]);
  9.         next;
  10.     }
  11.     push (@{$aData[-1][$_]}, $aList[$_]) for 1 .. $#aList;
  12. }

  13. print join ("\n", join (",", $_->[0], @{$_->[1]}), join (",", $_->[0], @{$_->[-1]})), "\n" for @aData;

  14. __DATA__
  15. PL -0.00 5.50
  16. PL -0.25 3.50
  17. PL -0.50 0.00
  18. PL -0.75 4.50
  19. -0.25 -0.00 1.00
  20. -0.25 -0.25 4.50
  21. -0.25 -0.50 1.00
  22. -0.75 -0.75 1.00
  23. -0.75 -1.00 0.00
  24. -1.00 -0.25 3.50
  25. -1.00 -0.50 0.00
  26. -1.00 -1.25 3.40
  27. -1.00 -1.75 4.00
复制代码

论坛徽章:
0
10 [报告]
发表于 2016-09-21 14:00 |只看该作者
高版本的直接装到自己家目录中试试呗~
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP