免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
12
最近访问板块 发新帖
楼主: xiaomm250

如何把2.txt里面有的行,但是1.txt里面没有的行,写到3.txt里面? [复制链接]

论坛徽章:
0
发表于 2014-04-13 15:30 |显示全部楼层
substr函数 发表于 2014-04-11 20:15
大致的思路

感觉运行结果是正确的

把这句
my %F1 = map { $_, 1 } <File1>;
换成这句
my %F1 = map { $_ } <File1>;
为什么结果不对呢?

论坛徽章:
6
丑牛
日期:2014-03-21 15:42:04子鼠
日期:2014-04-12 11:50:17处女座
日期:2014-09-01 09:25:1115-16赛季CBA联赛之吉林
日期:2015-12-22 14:01:5215-16赛季CBA联赛之广东
日期:2016-03-08 18:49:422016科比退役纪念章
日期:2016-07-06 12:19:55
发表于 2014-04-13 17:54 |显示全部楼层
假设文件不大,2.txt文件木有重复
下面也许能行{:3_188:}
  1. #!perl
  2. use Modern::Perl;
  3. use Set::Scalar;
  4. use File::Slurp qw{ read_file write_file };

  5. my @files  = ('1.txt', '2.txt', '3.txt');

  6. # save file lines to set
  7. my $set_for_file2 = Set::Scalar->new( read_file($files[2]) );
  8. my $set_for_file1 = Set::Scalar->new( read_file($files[1]) );

  9. my $set_for_file3 = $set_for_file2 - $set_for_file1;

  10. write_file($files[3], sort $set_for_file3->elements);

  11. __END__
复制代码
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP