前言
在数据结构算法设计中,或者一个方法的具体实现的时候,有一种方法叫做“递归”,这种方法在思想上并不是特别难,但是实现起来还是有一些需要注意的。虽然对于很多递归算法都可以由相应的循环迭代来代替,但是对于一些比较抽象复杂的算法不用递归很难理解与实现。
Java递归模糊查询文件
字符串模糊查询
public boolean matchStringByIndexOf(String str,String part) {
int count = 0;
int index = 0;
while( ( index = str.indexOf(part, index) ) != -1 )
{
index = index+part.length();
count++;
}
if(count < 1){
return false;
}
return true;
}
递归遍历文件
public List<String> searchFileList(File path, String fileName){
File[] files=path.listFiles(); //列出所有的子文件
for(File file :files)
{
if(file.isFile()){//如果是文件,则先模糊查询,判断是否相关
if(stringUtilService.matchStringByIndexOf(file.toString(),fileName)){
fileListData.add(file.toString());
}
}else if(file.isDirectory())//如果是文件夹,则输出文件夹的名字,并递归遍历该文件夹
{
searchFileList(file,fileName);//递归遍历
}
}
return fileListData;
}
测试
public static void main(String[] args) {
String A ="G:/HTML/testData/达芬奇";
File file = new File(A);
FileService fileService = new FileServiceImpl();
System.out.println(fileService.searchFileList(file,"myse").toString());
}
总结
到此这篇关于Java递归模糊查询文件的文章就介绍到这了,更多相关Java递归模糊查询文件内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!