java file.listFiles()按文件名稱、日期、大小排序

1:按 文件名稱 排序是什麼規則呢?

windows的命名規則是,特殊字符(標點、符號)> 數字 > 字母順序 > 漢字拼音。首字規則,首字相同看第二個,依次類推… 
例如:全是數字的情況,100<200<300 ;111<121<131; 111<112<113;

2:按 文件日期 排序是什麼規則呢?

按 文件日期 排序分兩種:

(1)按文件創建日期排序(比較特殊)
(2)按文件修改日期排序
文件創建日期排序:也就字面意思啦。 
文件修改日期排序:按照文件修改日期排序。

3:按 文件大小 排序是什麼規則呢?

這個就比較簡單了,按文件佔用內存的大小排序。

規則,清楚了。那麼,就進入正題。怎麼讓 file.listFiles() 返回的 File[ ] 是按照上面所說的規則排序呢?

1:按 文件名稱 排序

  public static void orderByName(String filePath) {
        File file = new File(filePath);
        File[] files = file.listFiles();
        List fileList = Arrays.asList(files);
        Collections.sort(fileList, new Comparator<File>() {
            @Override
            public int compare(File o1, File o2) {
                if (o1.isDirectory() && o2.isFile())
                    return -1;
                if (o1.isFile() && o2.isDirectory())
                    return 1;
                return o1.getName().compareTo(o2.getName());
            }
        });
        for (File file1 : files) {
            System.out.println(file1.getName());

        }
    }

打印的順序是:按照遞增的順序排列

2:按 文件日期 排序 
按 文件修改日期:遞增

public static void orderByDate(String filePath) {
        File file = new File(filePath);
        File[] files = file.listFiles();
        Arrays.sort(files, new Comparator<File>() {
            public int compare(File f1, File f2) {
                long diff = f1.lastModified() - f2.lastModified();
                if (diff > 0)
                    return 1;
                else if (diff == 0)
                    return 0;
                else
                    return -1;//如果 if 中修改爲 返回-1 同時此處修改爲返回 1  排序就會是遞減
            }

            public boolean equals(Object obj) {
                return true;
            }

        });
        for (int i = 0; i < files.length; i++) {
            System.out.println(files[i].getName());
            System.out.println(new Date(files[i].lastModified()));
        }

    }

 

3:按 文件大小 排序

 public static void orderByLength(String filePath) {
        File file = new File(filePath);
        File[] files = file.listFiles();
        List<File> fileList = Arrays.asList(files);
        Collections.sort(fileList, new Comparator<File>() {
            public int compare(File f1, File f2) {
                long diff = f1.length() - f2.length();
                if (diff > 0)
                    return 1;
                else if (diff == 0)
                    return 0;
                else
                    return -1;//如果 if 中修改爲 返回-1 同時此處修改爲返回 1  排序就會是遞減
            }

            public boolean equals(Object obj) {
                return true;
            }
        });
        for (File file1 : files) {
            if (file1.isDirectory()) continue;
            System.out.println(file1.getName() + ":" + file1.length());
        }
    }

這樣,打印的順序是:按照遞增的順序排列

 

喜歡本文的朋友們,歡迎關注微信公衆號“Java面試達人”,收看更多精彩內容

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章