文件操作

1.遞歸遍歷文件夾下所有的文件,包括子文件。

public static void listFile(File f) {
        if (f.isDirectory()) {

            File[] files = f.listFiles();
            if (null != files) {
                for (File file : files) {
                    listFile(file);

                }
            }

        }
        if (f.isFile()) {
            System.out.println(f);
        }
    }

主要用到了文件操作的三個方法
1.isDirectory:是不是文件夾
2.isFile:是不是文件
3.listFiles:列出改路徑下的所有File,返回一個File對象數(shù)組。

實現(xiàn):對傳入的File進行判斷,如果是文件,則輸出文件的名字,如果是文件夾,則列出該文件夾下的所有File,然后遞歸調(diào)用listFile()方法。

這里用到了static關(guān)鍵字,表示這個方法是類方法,不需要創(chuàng)建對象,就可以調(diào)用,通過類名就可以直接調(diào)用,用static修飾的方法是靜態(tài)方法。

2.遍歷文件夾,找出最大,最小文件

思路,設(shè)定最大最小值,然后遍歷,判斷是不是文件,是文件就和最大最小值比較,如果比最大值大,就交換,如果比最小值小,也進行交換。

 File f = new File("c:\\windows");
        File[] fs = f.listFiles();
        if(null==fs)
            return;
        long minSize = Integer.MAX_VALUE;
        long maxSize = 0;
        File minFile = null;
        File maxFile = null;
        for (File file : fs) {
            if(file.isDirectory())
                continue;
            if(file.length()>maxSize){
                maxSize = file.length();
                maxFile = file;
            }
            if(file.length()!=0 && file.length()<minSize){
                minSize = file.length();
                minFile = file;
            }
        }

3.拆分文件

思路:第一步,讀取文件到內(nèi)存中,然后存入一個byte數(shù)組中。
設(shè)置文件的大小,通過文件的length算出需要拆分成多少個文件,
計算出循環(huán)次數(shù),然后利用Arrays數(shù)組工具類的一個靜態(tài)方法,Arrays.copyOfRange(源數(shù)組, start, end));拆分為幾個數(shù)組,分別讀到不同的文件中。

        File file = new File("D:\\Everything\\Everything.exe");
        System.out.println("文件是否存在"+file.exists());
        try(FileInputStream fis = new FileInputStream(file);) {
            byte[] all = new byte[(int)file.length()];
            fis.read(all);
            int count=0;
            if(0==file.length()%(100*1024)){
                count=(int) (file.length()/(100*1024));
            }else{
                count=(int) (file.length()/(100*1024))+1;
            }
            
                int start =0;
                byte[] bs = null;
                for(int i =0;i<count;i++){
                    if(i!=count-1){
                         bs = Arrays.copyOfRange(all, start,start+(100*1024));
                        start+=(100*1024);
                    }else{
                        bs = Arrays.copyOfRange(all, start,(int) file.length());
                    }
                    
                    try(FileOutputStream fos = new FileOutputStream(new File("D:\\Everything\\evetything-"+i));){
                        fos.write(bs);
                    }
                    
                    
                }

        } catch (FileNotFoundException e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        } catch (IOException e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        }

4.合并文件

思路,先創(chuàng)建輸出流,然后利用while循環(huán),在循環(huán)中讀取一個,寫入一個,循環(huán)完成就合并為一個文件了。


最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

  • 如果要對文件產(chǎn)出文件內(nèi)容的開發(fā)操作,應(yīng)該使用java.io包完成,而在java.io包里面一個有五個核心類和一個核...
    落在牛背上的鳥閱讀 500評論 0 0
  • 1.創(chuàng)建文件夾 !/bin/sh mkdir -m 777 "%%1" 2.創(chuàng)建文件 !/bin/sh touch...
    BigJeffWang閱讀 10,491評論 3 53
  • java.io包里的類: InputStream/OutputStream : 以字節(jié)為單位讀寫文件內(nèi)容,一次讀/...
    buyaole閱讀 669評論 0 1
  • 1.1. File類(掌握) File課理解為文件和文件夾(目錄),用于表示磁盤中某個文件或文件夾的路徑。該類包含...
    王一萍o叩丁狼教育閱讀 1,340評論 0 0
  • 快節(jié)奏 生活不僅需要慢節(jié)奏,有時候也是需要快節(jié)奏來點綴一下的。慢節(jié)奏中能提高我們對于生活的悟性,...
    真真灼灼閱讀 575評論 5 10

友情鏈接更多精彩內(nèi)容