如何查找名称可能比预期名称长的文件



我正在做一些测试,我有很多文件需要对我进行数据分析。我们对文件有一个命名约定,但有时有人会在文件名中添加更多内容。我正在寻找一种方法来查找名称的"核心",然后保存整个文件名。

例如,我想查找WIRA_Rabcd_RT,但有人可能已将文件名保存为 RED_GREEN_BLUE_WIRA_Rabcd_RT.txt ,所以我的文件夹将如下所示:

RED_GREEN_BLUE_WIRB_Rabcd_RT.txt
RED_GREEN_BLUE_WIRC_Rabcd_RT.txt
RED_GREEN_BLUE_WIRA_Rabcd_RT.txt ← I want to find this file, and open it.
RED_GREEN_BLUE_WIRF_Rabcd_RT.txt
RED_GREEN_BLUE_WIRG_Rabcd_RT.txt
RED_GREEN_BLUE_WIRT_Rabcd_RT.txt
RED_GREEN_BLUE_WIRW_Rabcd_RT.txt
RED_GREEN_BLUE_WIRQ_Rabcd_RT.txt

glob 函数似乎可以解决问题:

my $dir = '/some/directory/';
my @files = glob($dir . '*WIRA_Rabcd_RT.txt');
# Make sure you get exactly one file, open it, etc.

在Perl TIMTOWTDI中,这是另一种方式:

#!/usr/bin/perl
use strict;
use warnings;
my $dir = 'dirname';
my $pattern = 'WIRA_Rabcd_RT';
my @files;
{ 
  opendir my $dir_handle, $dir;
  @files = grep { /$pattern/ } readdir $dir_handle;
} #end-of-block autocloses lexical $dir_handle 

@files现在包含目录中与模式匹配的文件的名称。请注意,名称是相对于该目录的(存储为 name 而不是 dir/name )。然后,我经常使用 File::chdir 模块将工作目录更改为$dir来处理这些文件。例如:

use File::chdir
# get @files in $dir as above...
{
  local $CWD = $dir;
  # work with files in @files
} 
# working directory restored to original here

相关内容

  • 没有找到相关文章

最新更新