1. 程式人生 > 實用技巧 >File 類、遞迴

File 類、遞迴

1.file類

當需要把記憶體中的資料儲存到持久化裝置上這個動作稱為輸出(寫)Output操作。

當把持久裝置上的資料讀取到記憶體中的這個動作稱為輸入(讀)Input操作。

因此我們把這種輸入和輸出動作稱為IO操作。

file類的方法

publicclassFileMethodDemo {

publicstaticvoidmain(String[] args) {

//建立檔案物件

File file = newFile("Test22.java");

//獲取檔案的絕對路徑,即全路徑

String absPath = file.getAbsolutePath();

//File中封裝的路徑是什麼獲取到的就是什麼。

String path = file.getPath();

//獲取檔名稱

String filename = file.getName();

//獲取檔案大小

longsize = file.length();

System.out.println("absPath="+absPath);

System.out.println("path="+path);

System.out.println("filename="+filename);

System.out.println("size="+size);

}

檔案和資料夾的建立刪除

publicclassFileMethodDemo2 {

publicstaticvoidmain(String[] args) throwsIOException {

// 對檔案或者檔案加進行操作。

File file = newFile("e:\\file.txt");

// 建立檔案,如果檔案不存在,建立 true 如果檔案存在,則不建立 false。 如果路徑錯誤,IOException

booleanb1 = file.createNewFile();

System.out.println("b1="+ b1);

//-----------刪除檔案操作-------注意:不去回收站。慎用------

booleanb2 = file.delete();

System.out.println("b2="+b2);

//-----------需要判斷檔案是否存在------------

booleanb3 = file.exists();

System.out.println("b3="+b3);

//-----------對目錄操作 建立,刪除,判斷------------

File dir = newFile("e:\\abc");

//mkdir()建立單個目錄。//dir.mkdirs();建立多級目錄

booleanb4 = dir.mkdir();

System.out.println("b4="+b4);

//刪除目錄時,如果目錄中有內容,無法直接刪除。

booleanb5 = dir.delete();

//只有將目錄中的內容都刪除後,保證該目錄為空。這時這個目錄才可以刪除。

System.out.println("b5="+ b5);

//-----------判斷檔案,目錄------------

File f = newFile("e:\\javahaha");// 要判斷是否是檔案還是目錄,必須先判斷存在。

// f.mkdir();//f.createNewFile();

System.out.println(f.isFile());

System.out.println(f.isDirectory());

}

1.1listFiles()方法介紹

publicclassFileMethodDemo3 {

publicstaticvoidmain(String[] args) {

File dir = newFile("e:\\java_code");

//獲取的是目錄下的當前的檔案以及資料夾的名稱。

String[] names = dir.list();

for(String name : names){

System.out.println(name);

}

//獲取目錄下當前檔案以及檔案物件,只要拿到了檔案物件,那麼就可以獲取其中想要的資訊

File[] files = dir.listFiles();

for(File file : files){

System.out.println(file);

}

}

}

注意:在獲取指定目錄下的檔案或者資料夾時必須滿足下面兩個條件

1,指定的目錄必須是存在的,

2,指定的必須是目錄。否則容易引發返回陣列為null,出現NullPointerException

檔案過濾器

public class MyFilter implements FileFilter {

    @Override
    public boolean accept(File pathname) {
        
        //獲取檔名
        String name=pathname.getName();
        //獲取檔案拓展名
        //轉小寫
        //判斷檔案是否以txt結尾
        return name.toLowerCase().endsWith(".txt");
    }

}

public static void main(String[] args) {
    File file=new File("D:\\io0512");
    File[] files=file.listFiles(new MyFilter());
    for(File f:files){
        System.out.println(f);
    }

遞迴

public static void main(String[] args) {
    System.out.println(a(3));
}
//遞迴計算1-100的和
public static int  a(int i){
    if(i==1){
        return 1;
    }else{
        return i+a(i-1);
    }
}

遞迴計算斐波那契數列(前兩個數相加等於第三個數)

public static void main(String[] args) {
    System.out.println(get(12));
}
public static int get(int n){
    if(n==1||n==2){
        return 1;
    }
    return get(n-1)+get(n-2);
}

遞迴應用

遞迴查詢所有檔案

public class Demo03 {
public static void main(String[] args) {
    get(new File("D:\\io0512"));
}
public static void get(File dir){
    //當前目錄這一級的檔案和資料夾物件陣列
    File[] files=dir.listFiles();
    for(File i:files){
        if(i.isDirectory()){//如果file物件時資料夾,繼續進行遍歷
            System.out.println(i+"---");//列印資料夾
            get(i);
        }else{
        //如果不是列印
        System.out.println(i);//列印檔案
        }
    }
}
}

遞迴查詢所有以txt結尾的檔案

public class Demo04 {
public static void main(String[] args) {
    get(new File("D:\\io0512"));
}
public static void get(File dir){
    //當前目錄這一集的檔案和資料夾物件陣列
    File[] files=dir.listFiles(new Zi());
    for(File i:files){
        if(i.isDirectory()){//如果file物件時資料夾,繼續進行遍歷
            //System.out.println(i+"---");//列印資料夾
            get(i);
        }else{
        //如果不是列印
        System.out.println(i);//列印檔案
    }}
}
}

public class Zi implements FileFilter{

    
    public boolean accept(File pathname) {
        if(pathname.isDirectory()){
            return true;
        }
        String i=pathname.getName();
        return i.toLowerCase().endsWith(".txt");
    }

}