perl – 量词在正则表达式中没有任何关系

我的要求是使用perl打印文件名中包含’xyz’文本的文件.
我在下面尝试并得到以下错误

量词在正则表达式中没有任何内容,标记为< - HERE,m / *< - HERE xyz.xlsx $/;

use strict;
use warnings;

my @files = qw(file_xyz.xlsx,file.xlsx);
my @my_files = grep { /*xyz.xlsx$/ } @files;
for my $file (@my_files) {
    print "The output $file \n";
}

当我在grep正则表达式中添加*时,问题就出现了.
我怎么可能实现这个目标?

解决方法

*是元字符,称为量词.这意味着“重复前一个字符或字符类零次或多次”.在您的情况下,它什么都不遵循,因此是语法错误.你可能正在尝试的是匹配任何东西,即.*:通配符,然后是量词.但是,这已经是正则表达式匹配的认行为,除非它已锚定.所以你需要的是:
my @my_files = grep { /xyz/ } @files;

你可以保持你的字符串锚xlsx $的结尾,但由于你有一个有限的文件名列表,这似乎没有必要.虽然您使用了qw()错误,但它不是以逗号分隔,而是以空格分隔:

my @files = qw(file_xyz.xlsx file.xlsx);

但是,如果您应该拥有更大的文件名集,例如从目录中读取的文件名,则可以在中间放置通配符字符串:

my @my_files = grep { /xyz.*\.xlsx$/i } @files;

请注意使用/ i修饰符来区分大小写不敏感.还要注意你必须逃脱.因为它是另一个元字符.

相关文章

1. 如何去重 #!/usr/bin/perl use strict; my %hash; while(...
最近写了一个perl脚本,实现的功能是将表格中其中两列的数据...
表的数据字典格式如下:如果手动写MySQL建表语句,确认麻烦,...
巡检类工作经常会出具日报,最近在原有日报的基础上又新增了...
在实际生产环境中,常常需要从后台日志中截取报文,报文的形...
最近写的一个perl程序,通过关键词匹配统计其出现的频率,让...