在进入正题之前,先明确一下以下这几个名词的概念。
1:按 文件名称 排序是什么规则呢?
windows的命名规则是,特殊字符(标点、符号)> 数字 > 字母顺序 > 汉字拼音。首字规则,首字相同看第二个,依次类推…
例如:全是数字的情况,100<200<300 ;111<121<131; 111<112<113;
2:按 文件日期 排序是什么规则呢?
按 文件日期 排序分两种:
- (1)按文件创建日期排序(比较特殊)
- (2)按文件修改日期排序
文件创建日期排序:也就字面意思啦。
文件修改日期排序:按照文件修改日期排序。
3:按 文件大小 排序是什么规则呢?
这个就比较简单了,按文件占用内存的大小排序。
规则,清楚了。那么,就进入正题。怎么让 () 返回的 File[ ] 是按照上面所说的规则排序呢?
1:按 文件名称 排序
public static void orderByName(String filePath) {
File file = new File(filePath);
File[] files = ();
List fileList = (files);
(fileList, new Comparator<File>() {
@Override
public int compare(File o1, File o2) {
if (() && ())
return -1;
if (() && ())
return 1;
return ().compareTo(());
}
});
for (File file1 : files) {
System.out.println(());
}
}
打印的顺序是:按照递增的顺序排列
2:按 文件日期 排序
(1)按 文件修改日期:递增
public static void orderByDate(String filePath) {
File file = new File(filePath);
File[] files = ();
(files, new Comparator<File>() {
public int compare(File f1, File f2) {
long diff = () - ();
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 < ; i++) {
System.out.println(files[i].getName());
System.out.println(new Date(files[i].lastModified()));
}
}
(2)按 文件创建日期 排序
由于这个比较复杂和特殊,后面专门讲解。
3:按 文件大小 排序
public static void orderByLength(String filePath) {
File file = new File(filePath);
File[] files = ();
List<File> fileList = (files);
(fileList, new Comparator<File>() {
public int compare(File f1, File f2) {
long diff = () - ();
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 (()) continue;
System.out.println(() + ":" + ());
}
}
这样,打印的顺序是:按照递增的顺序排列
下面,讲解一下上面遗留的一个问题。就是 按文件创建日期排序的问题。经过多方面的查询资料发现情况是这样的。
在jdk中,File的操作并没有取得文件创建时间的方法。唯一提供的方法是 lastModified()返回long值。牺牲创建时间的方法是在为了满足跨平台的需要。为什么这么说呢?
是因为以下几点原因:
1:”UNIX或LINUX平台下文件系统中就没有保存文件的创建时间,只有文件的最后修改的时间。否则的话,JAVA中File类就应该有支持这个属性的方法了.”
2:”在Linux中,没有文件创建时间的概念.只有文件的访问时间、修改时间、状态改变时间.也就是说不能知道文件的创建时间.”
3:”若LINUX下文件创建好以后全是文件读操作(没有执行过存盘操作),则取的文件修改时间就是文件创建的时间.”
看了上面的原因后,我想大家就明白为什么了吧。但是在windows环境中,需要取得文件创建时间的情况是存在的。
代码一:
/**
* 读取文件创建时间和最后修改时间
*/
public class ReadFileTime {
public static void main(String[] args) {
//getCreateTime();
getModifiedTime_1();
}
/**
* 读取文件创建时间
* 测试发现,并不好用
*/
public static void getCreateTime() {
String filePath = "F:\\filetest/";
String strTime = null;
try {
Process p = ().exec("cmd /C dir " + filePath + "/tc");
InputStream is = ();
BufferedReader br = new BufferedReader(new InputStreamReader(is));
String line;
while ((line = ()) != null) {
if ((".txt")) {
strTime = (0, 17);
break;
}
}
} catch (IOException e) {
();
}
("创建时间 " + strTime);
}
/**
* 读取文件修改时间的方法1
*/
public static void getModifiedTime_1() {
File f = new File("F:\\filetest/");
Calendar cal = ();
long time = ();
/* (time);
//此处toLocalString()方法已过时,但是仍可输出
("修改时间 " + ().toLocaleString());*/
SimpleDateFormat formatter = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
(time);
("修改时间 " + (()));
}
}
代码二:
实现的办法是通过windows本地命令行来取得创建日期。
public class Timetake {
public static void main(String[] args) {
String filePath = "F:\\filetest/";
//String filePath = "F:\\filetest\\";//路径这样写也可以的
File file = new File(filePath);
String time = (file);
(" time=" + time);
}
/**
* @param _file _file
* @return datetime datetime
* 测试发现这个方法好用,在 windows环境下
*/
public static String getFileCreateDate(File _file) {
File file = _file;
try {
Process ls_proc = ().exec(" /c dir " + () + " /tc");
BufferedReader br = new BufferedReader(new InputStreamReader(ls_proc.getInputStream()));
for (int i = 0; i < 5; i++) {
();
}
String stuff = ();
if (stuff == null) {
return "";
}
StringTokenizer st = new StringTokenizer(stuff);
String dateC = ();
String time = ();
String datetime = (time);
();
return datetime;
} catch (Exception e) {
return null;
}
}
}
参考博客:
Java读取文件创建时间(windows环境中):
/wq350778209/article/details/12844155
Java获得文件创建时间(windows环境中):
/s/blog_5e1e51bb0100e1c3.html
http:///content/13/0426/14/11965070_281066262.shtml