怎么用m!在Perl正则表达式

时间:2013-06-19 20:16:45

标签: regex perl

我第一次学习Perl和正则表达式,所以如果这是一个愚蠢的问题我会道歉。我一直在寻找自己的答案,但找不到任何东西。也许我的一部分问题是我真的不知道它叫什么。

我遇到了一段看起来像这样的代码:

$xl_file = "$curr_dir/$xl_file" unless $xl_file =~ ( m!(^[a-z]:)|[/\\]!i );

当我查看=〜运算符时,我潜入正则表达式洞并开始了解它。但我只看过“m //”匹配运算符。我假设“我!”是另一种匹配运算符,但我找不到任何解释它如何工作的引用。通过实验,我发现在使用它时需要“!i”,但这与我能想到的一样多......

有人可以向我解释一下这个问题,还是指点一些(免费)材料的方向?

2 个答案:

答案 0 :(得分:6)

使用匹配运算符,您可以使用任何类型的分隔符,而不仅仅是/

因此,以下所有匹配运算符都有效并执行相同的任务:

m//
m!!
m{}
m##

另请注意,如果您使用/作为分隔符,则可以从头开始删除m。因此,/foo/有效,但!foo!不是。

答案 1 :(得分:4)

不,这是完全一样的。在Perl中,您可以根据需要选择正则表达式分隔符。也就是说,

m/foo/
/foo/
m!foo!
m"foo"
m+foo+
m xfoox
m{foo}

都是相同的正则表达式(但从不使用问号作为分隔符,它们唤醒了一个古老的恶魔)。

在结束分隔符之后,放置正则表达式修饰符。 /i修饰符激活不区分大小写的匹配。

对于完整的爆炸,您可以潜入perlre以获取Perl正则表达式的所有隐藏块。但首先,perlretut应该更合适。