我正在从codeeval.com的挑战练习Perl,我得到一个意外的错误。我们的目标是逐行遍历一个文件,其中每行都有一个字符串和一个用逗号分隔的字符,并在该字符串中查找该字符的最右侧。我得到错误的答案回来,所以我改变了代码打印出来只是变量值,当我得到了以下错误:Perl - 不能使用字符串(...)作为数组参考
Can't use string ("Hello world") as an ARRAY ref while "strict refs" in use at char_pos.pl line 20, <FILE> line 1.
我的代码如下。您可以在标题中看到来自文件的示例。您还可以看到原始输出代码,该代码不正确地只显示每个字符串中最右侧的字符。
#CodeEval challenge: https://www.codeeval.com/open_challenges/31/
#Call with $> char_pos.pl numbers
##Hello world, d
##Hola mundo, H
##Keyboard, b
##Connecticut, n
#!/usr/bin/perl
use strict;
use warnings;
my $path = $ARGV[0];
open FILE, $path or die $!;
my $len;
while(<FILE>)
{
my @args = split(/,/,$_);
$len = length($args[0]) - 1;
print "$len\n";
for(;$len >= 0; $len--)
{
last if $args[0][$len] == $args[1];
}
#if($len > -1)
#{
# print $len, "\n";
#}else
#{
# print "not found\n";
#}
}
编辑: 基于下面的答案,这里是我开始工作的代码:
#!/usr/bin/perl
use strict;
use warnings;
use autodie;
open my $fh,"<",shift;
while(my $line = <$fh>)
{
chomp $line;
my @args = split(/,/,$line);
my $index = rindex($args[0],$args[1]);
print $index>-1 ? "$index\n" : "Not found\n";
}
close $fh;
如果您正在比较字符串,请检查'perldoc substr'而不是$ $ args [0] [$ len]'并使用'eq'。 – 2014-09-05 13:54:45
并使用'while(<>){...}'而不是明确地打开文件等;它更习惯Perl。当你检查文档时(注意它需要'perldoc -f substr'来查找函数'substr'的名字),查找'perldoc -f rindex'。您可能希望在'/,* /'上进行分割,以便在尾部的字母之前留出空格。 – 2014-09-05 14:09:42
提示:您可能更喜欢'我的($字,$字母)=拆分(/,/,$ _);'。 '@ args'是相当可怜的名字。 – ikegami 2014-09-05 15:17:34