免费注册 查看新帖 |

Chinaunix

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

[文本处理] 表中表排序 [复制链接]

论坛徽章:
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
1 [报告]
发表于 2017-03-16 13:11 |显示全部楼层
  1. #!/usr/bin/perl
  2. use strict;
  3. use warnings;

  4. my %hMaps = map {$_ => 1} ('7450 ESS', '7750 SR');
  5. print scalar <DATA>;
  6. while (<DATA>){
  7.     if (/\A\|-/){
  8.         print;
  9.         last;
  10.     }
  11.     my $src = (split (/\s*\|/))[2];
  12.     my @aT = $src =~ /[^;]+/g;
  13.     my @aOut = sort {$a cmp $b} grep ($hMaps{$_}, @aT);
  14.     push (@aOut, sort {$b =~ s/.*\s//r cmp $a =~ s/.*\s//r} grep (!$hMaps{$_}, @aT));
  15.     s/$src/join (';', @aOut)/e;
  16.     print;
  17. }

  18. __DATA__
  19. |EmpID.|Supported Products---------------------------|Open ARs|In Progress ARs|Pending ARs|
  20. |130310|7950 XRS;7750 SR;7450 ESS                    |      30|              9|         20|
  21. |409310|7750 SR;7210 SAS;7705 SAR;7450 ESS;7950 XRS  |      41|              7|         24|
  22. |313597|7210 SAS;7750 SR;7450 ESS;7950 XRS;7705 SAR  |      70|              2|         43|
  23. |612111|7210 SAS;7750 SR;7450 ESS;7950 XRS;7705 SAR  |      35|             12|         14|
  24. |856225|7450 ESS;7750 SR;7950 XRS;7210 SAS;7705 SAR  |      38|              8|         13|
  25. |838190|7450 ESS;7750 SR;7950 XRS                    |      23|              7|          5|
  26. |639763|7710 SR;7450 ESS;7210 SAS;7750 SR;7705 SAR   |      29|             13|          8|
  27. |167936|7701 CPAA;7210 SAS;7750 SR;7450 ESS;7950 XRS |      25|             11|         10|
  28. |686580|7210 SAS;7750 SR;7450 ESS;7950 XRS;7710 SR   |      42|              8|         19|
  29. |473732|7750 SR;9471 WMM;7450 ESS                    |      19|              4|         13|
  30. |306660|7705 SAR;7210 SAS;7750 SR;7450 ESS;7950 XRS  |      42|             11|         19|
  31. |------+---------------------------------------------+--------+---------------+-----------+
复制代码
perl abc.pl

论坛徽章:
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
2 [报告]
发表于 2017-03-16 13:11 |显示全部楼层
  1. #!/usr/bin/perl
  2. use strict;
  3. use warnings;

  4. my %hMaps = map {$_ => 1} ('7450 ESS', '7750 SR');
  5. print scalar <DATA>;
  6. while (<DATA>){
  7.     if (/\A\|-/){
  8.         print;
  9.         last;
  10.     }
  11.     my $src = (split (/\s*\|/))[2];
  12.     my @aT = $src =~ /[^;]+/g;
  13.     my @aOut = sort {$a cmp $b} grep ($hMaps{$_}, @aT);
  14.     push (@aOut, sort {$b =~ s/.*\s//r cmp $a =~ s/.*\s//r} grep (!$hMaps{$_}, @aT));
  15.     s/$src/join (';', @aOut)/e;
  16.     print;
  17. }

  18. __DATA__
  19. |EmpID.|Supported Products---------------------------|Open ARs|In Progress ARs|Pending ARs|
  20. |130310|7950 XRS;7750 SR;7450 ESS                    |      30|              9|         20|
  21. |409310|7750 SR;7210 SAS;7705 SAR;7450 ESS;7950 XRS  |      41|              7|         24|
  22. |313597|7210 SAS;7750 SR;7450 ESS;7950 XRS;7705 SAR  |      70|              2|         43|
  23. |612111|7210 SAS;7750 SR;7450 ESS;7950 XRS;7705 SAR  |      35|             12|         14|
  24. |856225|7450 ESS;7750 SR;7950 XRS;7210 SAS;7705 SAR  |      38|              8|         13|
  25. |838190|7450 ESS;7750 SR;7950 XRS                    |      23|              7|          5|
  26. |639763|7710 SR;7450 ESS;7210 SAS;7750 SR;7705 SAR   |      29|             13|          8|
  27. |167936|7701 CPAA;7210 SAS;7750 SR;7450 ESS;7950 XRS |      25|             11|         10|
  28. |686580|7210 SAS;7750 SR;7450 ESS;7950 XRS;7710 SR   |      42|              8|         19|
  29. |473732|7750 SR;9471 WMM;7450 ESS                    |      19|              4|         13|
  30. |306660|7705 SAR;7210 SAS;7750 SR;7450 ESS;7950 XRS  |      42|             11|         19|
  31. |------+---------------------------------------------+--------+---------------+-----------+
复制代码
perl abc.pl
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP