我正在开发一种工具来计算来自另一个程序的存档文件。因此,我使用 DirectoryStream 和过滤子目录以及一些带有简单 if 子句的文件(如下所示)。
对于我想知道的统计数据,平均每小时创建多少个文档。
我在处理文件和目录方面不是很有经验,但我想有某种“getLastModified”,将时间范围从最旧到最年轻,并计算每小时的平均文档数?
我正在开发一种工具来计算来自另一个程序的存档文件。因此,我使用 DirectoryStream 和过滤子目录以及一些带有简单 if 子句的文件(如下所示)。
对于我想知道的统计数据,平均每小时创建多少个文档。
我在处理文件和目录方面不是很有经验,但我想有某种“getLastModified”,将时间范围从最旧到最年轻,并计算每小时的平均文档数?
好吧,文件有一个lastModified()
方法,返回上次修改的时间戳。如果文件不存在或发生 I/O 错误,则返回 0。要将 a 转换Path
为 a,File
您可以使用该toFile()
方法。这样,计算文件/小时的平均值将相当容易:
long minTimestamp = Long.MAX_VALUE; // definitely greater than any timestamp you will ever find
long maxTimestamp = 0;
int count = 0;
try (DirectoryStream<Path> directoryStream = Files.newDirectoryStream(Paths.get("DIRECTORY PATH"))) {
for(Path path: directoryStream) {
if (!(Files.isDirectory(path) || path.toString().endsWith("\\databaseinfo.xml") || path.toString().endsWith(".log"))) {
long lastModified = path.toFile().lastModified();
if (lastModified > 0L) { // check that no error occurred
if (lastModified < minTimestamp) minTimestamp = lastModified; // new minimum
if (maxTimestamp < lastModified) maxTimestamp = lastModified; // new maximum
}
count = count + 1;
}
}
} catch (IOException e) {
e.printStackTrace();
}
System.out.println(count);
double filesPerHour = 0;
if (maxTimestamp != minTimestamp) { // avoid division by 0
filesPerHour = (double) count * 60 * 60 * 1000 / (maxTimestamp - minTimestamp); // 60 * 60 * 1000 = milliseconds in one hour
}
System.out.println(filesPerHour);
编辑:反转 if 条件,以避免在 else 块中有代码的空 if 语句