现在有个文件数组,里面的文件名有一定的规律(按文件名排序是不行的),共性是文件名都包含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); } }
本回答被题主选为最佳回答 , 对您是否有帮助呢?解决 无用评论 打赏 举报
悬赏问题
- ¥30 关于#r语言#的问题:如何对R语言中mfgarch包中构建的garch-midas模型进行样本内长期波动率预测和样本外长期波动率预测
- ¥15 ETLCloud 处理json多层级问题
- ¥15 matlab中使用gurobi时报错
- ¥15 这个主板怎么能扩出一两个sata口
- ¥15 不是,这到底错哪儿了😭
- ¥15 2020长安杯与连接网探
- ¥15 关于#matlab#的问题:在模糊控制器中选出线路信息,在simulink中根据线路信息生成速度时间目标曲线(初速度为20m/s,15秒后减为0的速度时间图像)我想问线路信息是什么
- ¥15 banner广告展示设置多少时间不怎么会消耗用户价值
- ¥15 可见光定位matlab仿真
- ¥15 arduino 四自由度机械臂