现在有个文件数组,里面的文件名有一定的规律(按文件名排序是不行的),共性是文件名都包含MMddHHmmss格式的日期,现在想要根据这个时间找出最早的文件,这只能用排序算法吗?请问有什么比较快的方法吗,效率要高一点的?
哈哈,给你代码之前说一句:talk is cheap show me the code
package csdn20220824;
import java.io.File;
import java.util.ArrayList;
import java.util.List;
/**
* @Description
* @Author wangFei
* @Date 2022/8/24 9:35
* @Version 1.0
**/
public class Test {
/**
* 字符串包含连续14位数字
*/
private final static String REG = "^.*\\d{14}.*$";
public static void main(String[] args) {
File file = new File("D://test/");
List<Long> list = new ArrayList<>();
File[] files = file.listFiles();
for (File f : files) {
if (f.getName().matches(REG)) {
// 文件名包含连续14位数字的参与排序
String s = numberStr(f.getName());
if (s.length() == 14) {
// 截取连续字符串,并且长度必须是14,也就是标准的yyyyMMddHHmmss
Long l = Long.parseLong(s);
list.add(l);
}
}
}
// 得到时间最早的时间串
Long oldStr = list.stream().min(Long::compareTo).get();
for (File f : files) {
if (f.getName().contains(oldStr + "")) {
System.out.println(f.getName());
}
}
}
public static String numberStr(String str){
int max = 0,count = 0,end = 0;
for (int i = 0; i < str.length(); i++) {
if(str.charAt(i) >= '0' && str.charAt(i) <= '9'){
count++;
if(max < count){
max = count;
end = i;
}
}else{
count = 0;
}
}
return str.substring(end - max + 1,end + 1);
}
}
这不就是排序算法吗。
File不是有一个file.listFiles()方法吗?这样你可以获取同一目录下所有文件,然后根据文件名排序,就可以达到你的目的
把文件名全部提取出来,在提取的同时把文件名中的日期提取出来。然后将文件名和提取出来的日期塞到数据库里面去。
好了,现在你可以在数据库里面用sql结果了,正看逆看都通过sql查就完了。
至于如何提取日期,在网上查。不过我们一般处理这样的文件的时候,都是把日期和其他字符用下划线隔开的,这样后期好提取。
你的这个没有年份啊,如何确定时间