免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
楼主: mouse.rice
打印 上一主题 下一主题

比较两段CODE,请您帮修改!谢谢~ [复制链接]

论坛徽章:
0
1 [报告]
发表于 2008-01-17 09:39 |显示全部楼层
原帖由 mouse.rice 于 2008-1-17 08:20 发表
回Lonki:
希望通过后面一个代码实现前者代码的结果。用ID.txt替换qw//中的内容,方便用户维护ID,谢谢!
ID.txt的内容如下:
001 002 004 006 008......(近3K个ID)

#!/usr/bin/perl

use strict;
my ...

如果你的array仅仅提供查询hash作为key使用,那这个数组完全是多余的啊
你后面写法也有问题,你直接使用$hash{$key},如果$key不在hash里面呢?

所以可以这样考虑
  1. while(<ID>){
  2.    print "$_\t$hash{$_}\n" if exists($hash{$_});
  3. }
复制代码

而且你还得考虑,如果不巧,你那个id后面写了空值"",你可能打印出空白

论坛徽章:
0
2 [报告]
发表于 2008-01-17 12:49 |显示全部楼层

回复 #10 mouse.rice 的帖子


你把你全部代码贴出来看看,那写法,如果没有输出,连空行都没有
那就说明exists为假,就说hash里面没这些ID
大概和文件格式或者读写操作有关吧,为了保险起见
print前面最好加句 $_=~s/\s//g;

改一下吧:

  1. while(<ID>){
  2.     s/\s//g;
  3.     if(exists($hash{$_})){
  4.       print "$_\t$hash{$_}\n";
  5.     }else{ warn "****$_****\n";
  6. }
复制代码

这样就清晰了

[ 本帖最后由 perljoker 于 2008-1-17 12:57 编辑 ]

论坛徽章:
0
3 [报告]
发表于 2008-01-18 09:50 |显示全部楼层

Lonki代码确实漂亮……,不过
my %id_all = map { /(\d+)\s+(.*)\s*/ } <ID_ALL>;
这句话我确实没看懂,map左边是hash,map里面是个正则
这样做会得到什么结果呢?还是竟然能得到$1和$2?

to LZ,我那个s/\s//g 因为后面有个g,所有会把所有空白替换掉……

论坛徽章:
0
4 [报告]
发表于 2008-01-18 09:58 |显示全部楼层

回复 #18 ly5066113 的帖子

那个不是都能用@ARGV识别么?

论坛徽章:
0
5 [报告]
发表于 2008-01-18 10:32 |显示全部楼层

回复 #21 mouse.rice 的帖子


确实如此
map会自动返回后面正则表达式得到的$1和$2作为对值返回
他第二个表达式要容易看懂
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP