2

假设我在一个文件夹中有这样的文件:

  • myfile_mark_1.mp4
  • myfile_john_2.mp4
  • myfile_jake_3.mp4
  • myfile_tristan_4.mp4
  • yourfile_mark_1.mp4

如何查找前缀和后缀中仅包含“myfile_”的名称为3 或更少的文件("_3.mp4" , "_2.mp4" , "_1.mp4" , 像这样)。

所以在我的程序中我可以得到:

  • myfile_mark_1.mp4
  • myfile_john_2.mp4 和
  • myfile_jake_3.mp4

我试过这个,希望能走运,但我没有得到任何结果。:D

String myDirectory = Environment.getExternalStorageDirectory().getAbsolutePath();
File f = new File(myDirectory);
if (f.exists() && f.isDirectory()){
    final Pattern p = Pattern.compile("myfile_*\\_(^0*(1?\\d|%d)$).mp4"); // I know I really have a stupid mistake on the regex;

    File[] flists = f.listFiles(new FileFilter(){
        @Override
        public boolean accept(File file) {
            return p.matcher(file.getName()).matches();
        }
    });

    String s = "wait a minute, i'm debugging";
}

我希望有人可以帮助解决我的问题。

4

4 回答 4

6

所需的正则表达式非常简单。

myfile_.*_[123]\\.mp4
于 2013-08-12T05:46:03.100 回答
4

尝试这个 :-

 String myDirectory = Environment
        .getExternalStorageDirectory().getAbsolutePath();
 File f = new File(myDirectory);
 if (f.exists() && f.isDirectory()) {
    final Pattern p = Pattern.compile("yourfile_.*_[123]\\.png"); 
 File[] flists = f.listFiles(new FileFilter() {
    @Override
    public boolean accept(File file) {
        p.matcher(file.getName()).matches();
        Log.e("MIS", "sdsdsdsds" + p.matcher(file.getName()).matches());

        return p.matcher(file.getName()).matches();

    }
});
String s = "wait a minute, i'm debugging";

}

于 2013-08-12T05:52:58.237 回答
1

如果您想使用 来执行此操作Pattern,这里有一个工作示例,因为Pattern您使用的有很多问题。

String mark = "myfile_mark_1.mp4";
String john = "myfile_john_2.mp4";
String jake = "myfile_jake_3.mp4";

Pattern pattern = Pattern.compile("myfile_\\p{Alpha}+_\\d+\\.mp4");
Matcher matcher = pattern.matcher(mark);
System.out.println(matcher.find());
matcher = pattern.matcher(john);
System.out.println(matcher.find());
matcher = pattern.matcher(jake);
System.out.println(matcher.find());

输出:

true
true
true

我在Pattern您使用时发现的问题:

  • 我将该^0部分解释为可选的起始字符。字符可以表示整个输入的开始,^也可以表示字符或组的否定(仅适用于字符类)。
  • .你的Pattern必须逃脱。
  • 不知道你的%d意思是什么Pattern,因为它没有反映你的例子中的任何内容。是因为您想对数字进行分组并反向引用它们吗?在这种情况下,您可以将数字表达式括在圆括号中 - 在这种情况下,它将是您的 index-1 组。
于 2013-08-12T05:40:56.967 回答
0

尝试这样的事情。我认为这很容易

 String fileName="myfile_mark_1.mp4";
    if(fileName.startsWith("myfile")){
       if(Integer.parseInt(fileName.split("_")[2].substring(0,1))<=3){
           System.out.println(fileName);
       }
    }

以下将返回您计算机中与您的条件匹配的所有文件。

 public static void main(String[] args) {
    File[] paths = File.listRoots();
    for(File directory:paths){
        getFile(directory.toString());
    }
}

public static void getFile(String directoryName) {
    File directory = new File(directoryName);
    File[] fList = directory.listFiles();
    if(fList!=null){
        for (File file : fList) {
            if (file.isFile()) {
                if(file.getName().toString().startsWith("myfile")){
                    if(Integer.parseInt(file.getName().toString().split("_")[2].substring(0,1))<=3){
                        System.out.println(file.getName().toString());
                    }
                }
            } else if (file.isDirectory()) {
                getFile(file.getAbsolutePath());
            }
        }
    }

}
于 2013-08-12T05:38:33.650 回答