下面是應(yīng)用JAVA實現(xiàn)WINDOWS中的dir/s查找的一個實例: import java.io.File; import java.util.regex.Matcher; import java.util.regex.MatchResult; import java.util.regex.Pattern; import java.util.regex.PatternSyntaxException; /** *利用JAVA實現(xiàn)WINDOWS中的dir/s查找 *這里采用正則達式解決了通配符的問題,但是有一點就是不能夠通過命令行傳參數(shù) *因為如果你通過命令行傳數(shù),JAVA會自動把你的帶通過的文件名,換成當前目錄匹配的文件名, *如你在命令行以這樣傳入:javaFileSearcha*,如果當前目錄下有a.jpg,a1.jpg,那么a* *會被自動換成a.jpg,及a1.jpg,如果在當前目錄下有目錄,并且子目錄中有a2.jpg,那這個就查 *不出來。所有現(xiàn)在只能通過其它的方式調(diào)用才行,而不能夠通過命令行傳參數(shù) *這個可能需要攔截器才能夠解決這個問題,不過,這個我不會,如果會的并且有興趣,可以試試 *作者:blog.csdn.net/fenglibing *注:可以直接運行該程序,不過,你最好把該程序拷到你需要的根目錄下執(zhí)行。 */ publicclass FileSearch { String fileName; String currentPath; booleanregStr; Pattern pattern; public FileSearch(String fileName) { /*********************用正則表達式解決通配符***************************/ if(fileName.indexOf("*")!=-1 || fileName.indexOf("?")!=-1) { regStr=true; if(fileName.indexOf("?")!=-1) { fileName=fileName.replace("?",".{0,1}"); } /**********因為正則表式中的’*’和DOS中的功能差不多,所以不換***********/ pattern=Pattern.compile(fileName); } this.fileName=fileName; File f=new File(""); //從當前路徑開始查找 currentPath=f.getAbsolutePath(); doSearch(currentPath); } privateboolean doSearch(String path) { if(path==null) returnfalse; File F = new File(path); File[] allFile = F.listFiles(); //取得當前目錄下面的所有文件,將其放在文件數(shù)組中 int totalNum = allFile.length; //取得當前文件夾中有多少文件(包括文件夾) int currentFile = 0; for (currentFile = 0; currentFile < totalNum; currentFile++) { if (!allFile[currentFile].isDirectory()) { //如果是文件是采用處理文件的方式 if(regStr==true) { Matcher matcher=pattern.matcher(allFile[currentFile].getName()); boolean result=matcher.find(); if(result) { System.out.println(allFile[currentFile].getAbsolutePath()); } } elseif (allFile[currentFile].getName().equals(fileName)) { System.out.println(allFile[currentFile].getAbsolutePath());
} } //如果是文件夾就采用遞歸處理 else { doSearch(allFile[currentFile].getPath()); } } returntrue; } publicstaticvoid main(String[] args) { FileSearch fileSearch = new FileSearch("t?.jpg"); } }
|