免费注册 查看新帖 |

Chinaunix

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

求助文本处理 [复制链接]

论坛徽章:
0
1 [报告]
发表于 2017-03-22 12:52 |显示全部楼层
本帖最后由 Okelani 于 2017-03-22 12:54 编辑

把文件A读作哈希
判断B的第一列ID是否出现在哈希A里

  1. #!/usr/bin/perl
  2. my ( $fileA, $fileB ) = qw/A B/;
  3. open my $A, $fileA or die "$fileA: ", $!;
  4. open my $B, $fileB or die "$fileB: ", $!;

  5. my %A_has = map { $_, chomp } <$A>;

  6. while (<$B>) {
  7.     my ($id) = split /\./;
  8.     print if $A_has{$id};
  9. }
复制代码

把两个文件都读作数组。

也能解决问题, 效率有差别。

  1. #!/usr/bin/perl

  2. my ( $fileA, $fileB ) = qw/A B/;
  3. open my $A, $fileA or die "$fileA: ", $!;
  4. open my $B, $fileB or die "$fileB: ", $!;

  5. my @A = grep { chomp } <$A>;
  6. my @B = <$B>;

  7. for my $B (@B) {
  8.     my ($id) = split /\./, $B;
  9.     for my $ID (@A) {
  10.         if ( $id eq $ID ) {
  11.             print $B;
  12.             last;
  13.         }
  14.     }
  15. }
复制代码
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP