0

高性能のファイル検索プログラムを作成する必要があるという要件が1つありました。このプログラムは、提供された名前パターンに一致するすべてのファイルとフォルダーを最上位のフォルダーから順にリストし、サブフォルダーで再帰的に検索することになっています。

プログラムは、次の入力を使用してコマンドラインメインクラスにすることができます

検索を開始する最上位のフォルダー。C:\MyFoldersの例検索するアイテムのタイプ。ファイルまたはフォルダー、あるいはその両方検索パターンjava正規表現(java.util.regex)がパターンとして受け入れられます

MFile.tx?アプリケーションが戻る必要のあるUMFile123.txtとAIIMFile.txsのタイムアウト(秒単位)を検出します。それ以外の場合は、「操作を完了できませんでした」というメッセージを返す必要があります。

私はそれであるアノターアプローチを思いついた。

import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.util.List;

import com.sapient.test.fileSearch.FileSearch;

public class FilesearchMain {

    /**
     * @param args
     */
    public static void main(String[] args) {
        // TODO Auto-generated method stub
        int flag=0;
        System.out.println("Type Item to Search ");
        System.out.println("1 File");
        System.out.println("2 Folder ");
        System.out.println("3 Both");
        System.out.println("0 Exit");

        try{
        BufferedReader readType = new BufferedReader(new InputStreamReader(System.in));


        String searchType =readType.readLine();;

        System.out.println("Enter name of file to search ::");

        BufferedReader readName = new BufferedReader(new InputStreamReader(System.in));
        String fileName=readName.readLine();


        if(searchType==null && fileName==null){
            throw new Exception("Error Occured::Provide both the input Parameters");
        }
        validateInputs(searchType,fileName);
        FileSearch fileSearch = new FileSearch(searchType,fileName);
List resultList=fileSearch.findFiles();
        System.out.println(resultList);
        }catch(IOException io){
            System.out.println("Error Occured:: Check the input Parameters and try again");
        }catch(Exception e){
            System.out.println(e.getMessage());
        }
    }

    private static void validateInputs(String searchType, String fileName) 
    throws Exception{
        if(!(searchType.equals("1") || searchType.equals("2") || searchType.equals("3")) ){
            throw new Exception("Error:: Item to search can be only 1 or 2 or 3");
        }
        if(searchType.equals("") || fileName.equals("")){
            System.out.println("Error Occured:: Check the input Parameters and try again");

        }

    }

}

他のファイルは...

public class FileSearch {
    private String searchType;
    private String fileName;

    public FileSearch(){

    }
    public FileSearch(String sType,String fName){
        this.searchType=sType;
        this.fileName=fName;
    }

    public String getSearchType() {
        return searchType;
    }
    public void setSearchType(String searchType) {
        this.searchType = searchType;
    }
    public String getFileName() {
        return fileName;
    }
    public void setFileName(String fileName) {
        this.fileName = fileName;
    }
    public List findFiles(){

        File file = new File("C:\\MyFolders");

        return searchInDirectory(file);

    }
    //Assuming that files to search should contain the typed name by the user
    //
    private List searchInDirectory(File dirName){
        List<String> filesList = new ArrayList<String>();
        if(dirName.isDirectory()){
            File [] listFiles = dirName.listFiles();
            for(File searchedFile : listFiles){
                if(searchedFile.isFile() && searchedFile.getName().toUpperCase().contains(getFileName().toUpperCase())&& 
                        (getSearchType().equals("1") || getSearchType().equals("3") ) ){
                    filesList.add(searchedFile.getName());
                }else if(searchedFile.isDirectory() && searchedFile.getName().toUpperCase().contains(getFileName().toUpperCase())
                    &&  (getSearchType().equals("2") || getSearchType().equals("3") ) ){
                    filesList.add(searchedFile.getName());
                    searchInDirectory(searchedFile);
                }else{
                    searchInDirectory(searchedFile);
                }
            }
        }
        return filesList;
    }

}


Please advise is this approach is correct as per design..!Please update ..!1
4

1 に答える 1

0

いいえ。あなたは、と比較しているだけなので、実行していない正規表現を検索したいと言っていますcontains。これが単純な演習以上のものである場合は、メソッドFile.listFiles()Guavaの PatternFilenameFilterメソッドを確認することをお勧めします。プログラムを実行できる時間を本当に制限したい場合は、Guavaをご覧くださいSimpleTimeLimiter。ただし、Geneがコメントで述べたように、単純findなツールが必要な場合は、他のツールの方が適切な場合があります。

于 2012-08-06T06:56:43.883 に答える