[java] view plain copy
package net.xsoftlab.baike
import java.io.File
import java.io.FileFilter
import java.util.ArrayList
import java.util.List
//查找目录下指定文件名的文件
public class TextSearchFile {
static int countFiles = 0// 声明统计文件个数的变量
static int countFolders = 0// 声明统计文件夹的变量
public static File[] searchFile(File folder, final String keyWord) {// 递归查找包含关键字的文件
File[] subFolders = folder.listFiles(new FileFilter() {// 运用内部匿名类获得文件
@Override
public boolean accept(File pathname) {// 实现FileFilter类的accept方法
if (pathname.isFile())// 如果是文件
countFiles++
else
// 如果是目录
countFolders++
if (pathname.isDirectory()
|| (pathname.isFile() &&pathname.getName().toLowerCase().contains(keyWord.toLowerCase())))// 目录或文件包含关键字
return true
return false
}
})
List<File>result = new ArrayList<File>()// 声明一个集合
for (int i = 0i <subFolders.lengthi++) {// 循环显示文件夹或文件
if (subFolders[i].isFile()) {// 如果是文件则将文件添加到结果列表中
result.add(subFolders[i])
} else {// 如果是文件夹,则递归调用本方法,然后把所有的文件加到结果列表中
File[] foldResult = searchFile(subFolders[i], keyWord)
for (int j = 0j <foldResult.lengthj++) {// 循环显示文件
result.add(foldResult[j])// 文件保存到集合中
}
}
}
File files[] = new File[result.size()]// 声明文件数组,长度为集合的长度
result.toArray(files)// 集合数组化
return files
}
public static void main(String[] args) {// java程序的主入口处
File folder = new File("E:/baidu")// 默认目录
String keyword = "1231"
if (!folder.exists()) {// 如果文件夹不存在
System.out.println("目录不存在:" + folder.getAbsolutePath())
return
}
File[] result = searchFile(folder, keyword)// 调用方法获得文件数组
System.out.println("在 " + folder + " 以及所有子文件时查找对象" + keyword)
System.out.println("查找了" + countFiles + " 个文件," + countFolders + " 个文件夹,共找到 " + result.length + " 个符合条件的文件:")
for (int i = 0i <result.lengthi++) {// 循环显示文件
File file = result[i]
System.out.println(file.getAbsolutePath() + " ")// 显示文件绝对路径
}
}
}
Java程序中读取某个目录下的所有文件(下面以D盘下的baidu文件夹为例),代码如下:import java.io.File
public class Test1 {
public static void main(String[] args) {
String path="D:/baidu/"
File file=new File(path)
File[] tempList = file.listFiles()
System.out.println("该目录下对象个数:"+tempList.length)
for (int i = 0i <tempList.lengthi++) {
if (tempList[i].isFile()) {
//读取某个文件夹下的所有文件
System.out.println("文件:"+tempList[i])
}
if (tempList[i].isDirectory()) {
//读取某个文件夹下的所有文件夹
System.out.println("文件夹:"+tempList[i])
}
}
}
}
我写了一段遍历某个文件查找指定文件的,你自己改成你需要的功能。import java.io.File
import java.util.HashMap
public class Test1 {
static HashMap<String, String>filelist=new HashMap<String, String>()
/**
* 递归方法
* @param path 文件路径
*/
public static void find(String path){
File file=new File(path)
File[] files = file.listFiles()
//如果文件数组为null则返回
if (files == null)
return
for (int i = 0i <files.lengthi++) {
if (files[i].isDirectory()) {
//判断是不是文件夹,如果是文件夹则继续向下查找文件
find(files[i].getAbsolutePath())
} else {
//记录文件路径
String filePath = files[i].getAbsolutePath().toLowerCase()
//记录文件名
String fileName=files[i].getName().toLowerCase()
//System.out.println("---"+strFileName)
filelist.put(fileName, filePath)
}
}
}
public static void main(String[] args) {
//需要遍历的路径,也就是你要查找文件所在的路径
String path="D:\\kpi\\"
find(path)
System.out.println("kpi.9的路径:"+filelist.get("kpi.9"))
//输出结果:d:\kpi\kpi.9
}
}
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)