现在有个文件数组,里面的文件名有一定的规律(按文件名排序是不行的),共性是文件名都包含MMddHHmmss格式的日期,现在想要根据这个时间找出最早的文件,这只能用排序算法吗?请问有什么比较快的方法吗,效率要高一点的?
5条回答 默认 最新
- 小飞LOVE霞 2022-08-24 10:10关注
哈哈,给你代码之前说一句: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); } }
本回答被题主选为最佳回答 , 对您是否有帮助呢?解决 无用评论 打赏 举报
悬赏问题
- ¥15 对于这个问题的代码运行
- ¥50 三种调度算法报错 有实例
- ¥15 关于#python#的问题,请各位专家解答!
- ¥200 询问:python实现大地主题正反算的程序设计,有偿
- ¥15 smptlib使用465端口发送邮件失败
- ¥200 总是报错,能帮助用python实现程序实现高斯正反算吗?有偿
- ¥15 对于squad数据集的基于bert模型的微调
- ¥15 为什么我运行这个网络会出现以下报错?CRNN神经网络
- ¥20 steam下载游戏占用内存
- ¥15 CST保存项目时失败