java获取该路径下所有 Excel 文件(含子文件夹下),并把 Excel 文件最后修改时间为:一 周之内的 Excel 内容,合并到 mzy-merge.xlsx 文件中。 ② mzy-merge.xlsx 文件中,每个被合并文件内容最前部插入:该文件绝对路

时间: 2024-01-22 12:17:51 浏览: 23
径和最后修改时间。以下是 Java 代码实现: ```java import java.io.File; import java.io.FileInputStream; import java.io.FileOutputStream; import java.io.IOException; import java.nio.file.Files; import java.nio.file.attribute.BasicFileAttributes; import java.text.SimpleDateFormat; import java.util.Calendar; import java.util.Date; import org.apache.poi.ss.usermodel.Cell; import org.apache.poi.ss.usermodel.CellType; import org.apache.poi.ss.usermodel.Row; import org.apache.poi.ss.usermodel.Sheet; import org.apache.poi.ss.usermodel.Workbook; import org.apache.poi.xssf.usermodel.XSSFWorkbook; public class MergeExcelFiles { private static final String MERGE_FILE_NAME = "mzy-merge.xlsx"; private static final SimpleDateFormat DATE_FORMAT = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss"); public static void main(String[] args) { try { Workbook workbook = new XSSFWorkbook(); Sheet sheet = workbook.createSheet("merged data"); // Create header row Row headerRow = sheet.createRow(0); Cell cell1 = headerRow.createCell(0); cell1.setCellValue("File Path"); Cell cell2 = headerRow.createCell(1); cell2.setCellValue("Last Modified"); Cell cell3 = headerRow.createCell(2); cell3.setCellValue("Data"); // Get all Excel files in the given directory and its subdirectories File directory = new File("C:\\path\\to\\directory"); File[] allFiles = directory.listFiles((dir, name) -> name.toLowerCase().endsWith(".xlsx")); int rowCount = 1; for (File file : allFiles) { // Check if file was modified within the last week BasicFileAttributes attributes = Files.readAttributes(file.toPath(), BasicFileAttributes.class); Calendar lastWeek = Calendar.getInstance(); lastWeek.add(Calendar.DATE, -7); if (attributes.lastModifiedTime().toMillis() < lastWeek.getTimeInMillis()) { continue; } // Open Excel file and read data FileInputStream inputStream = new FileInputStream(file); Workbook inputWorkbook = new XSSFWorkbook(inputStream); Sheet inputSheet = inputWorkbook.getSheetAt(0); int rows = inputSheet.getPhysicalNumberOfRows(); for (int i = 0; i < rows; i++) { Row inputRow = inputSheet.getRow(i); if (inputRow != null) { Row outputRow = sheet.createRow(rowCount); // Insert file path and last modified time Cell filePathCell = outputRow.createCell(0); filePathCell.setCellValue(file.getAbsolutePath()); Cell lastModifiedCell = outputRow.createCell(1, CellType.STRING); lastModifiedCell.setCellValue(DATE_FORMAT.format(new Date(attributes.lastModifiedTime().toMillis()))); // Copy cell contents to output row int cells = inputRow.getPhysicalNumberOfCells(); for (int j = 0; j < cells; j++) { Cell inputCell = inputRow.getCell(j); if (inputCell != null) { Cell outputCell = outputRow.createCell(j + 2); outputCell.setCellValue(inputCell.getStringCellValue()); } } rowCount++; } } inputWorkbook.close(); inputStream.close(); } // Save merged data to file FileOutputStream outputStream = new FileOutputStream(MERGE_FILE_NAME); workbook.write(outputStream); workbook.close(); outputStream.close(); } catch (IOException e) { e.printStackTrace(); } } } ``` 这个代码可以获取指定目录下所有扩展名为 ".xlsx" 的 Excel 文件,然后筛选出最后修改时间为一周内的文件。接着,读取每个文件的内容,并将文件的绝对路径和最后修改时间插入到每个行的前两列中。最后,将所有数据合并到一个新的 Excel 文件中。注意,在运行代码之前需要添加 Apache POI 依赖。

最新推荐

recommend-type

java读取excel文件并复制(copy)文件到指定目录示例

主要介绍了java读取excel文件并复制文件到指定目录示例,需要的朋友可以参考下
recommend-type

Java遍历文件夹下所有文件并重新命名

主要为大家详细介绍了Java遍历文件夹下所有文件并重新命名,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
recommend-type

java递归实现复制一个文件夹下所有文件功能

主要介绍了java递归实现复制一个文件夹下所有文件功能,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
recommend-type

Java实现读取文件夹下(包括子目录)所有文件的文件名

主要介绍了Java实现读取文件夹下(包括子目录)所有文件的文件名,本文把代码组织成了一个模块,可以很方便的使用,需要的朋友可以参考下
recommend-type

Android遍历所有文件夹和子目录搜索文件

为了准确搜索文件,大家可以采取什么方法查找文件,本文为大家介绍Android遍历所有文件夹和子目录实现文件搜索功能,感兴趣的小伙伴们可以参考一下
recommend-type

zigbee-cluster-library-specification

最新的zigbee-cluster-library-specification说明文档。
recommend-type

管理建模和仿真的文件

管理Boualem Benatallah引用此版本:布阿利姆·贝纳塔拉。管理建模和仿真。约瑟夫-傅立叶大学-格勒诺布尔第一大学,1996年。法语。NNT:电话:00345357HAL ID:电话:00345357https://theses.hal.science/tel-003453572008年12月9日提交HAL是一个多学科的开放存取档案馆,用于存放和传播科学研究论文,无论它们是否被公开。论文可以来自法国或国外的教学和研究机构,也可以来自公共或私人研究中心。L’archive ouverte pluridisciplinaire
recommend-type

MATLAB柱状图在信号处理中的应用:可视化信号特征和频谱分析

![matlab画柱状图](https://img-blog.csdnimg.cn/3f32348f1c9c4481a6f5931993732f97.png) # 1. MATLAB柱状图概述** MATLAB柱状图是一种图形化工具,用于可视化数据中不同类别或组的分布情况。它通过绘制垂直条形来表示每个类别或组中的数据值。柱状图在信号处理中广泛用于可视化信号特征和进行频谱分析。 柱状图的优点在于其简单易懂,能够直观地展示数据分布。在信号处理中,柱状图可以帮助工程师识别信号中的模式、趋势和异常情况,从而为信号分析和处理提供有价值的见解。 # 2. 柱状图在信号处理中的应用 柱状图在信号处理
recommend-type

HSV转为RGB的计算公式

HSV (Hue, Saturation, Value) 和 RGB (Red, Green, Blue) 是两种表示颜色的方式。下面是将 HSV 转换为 RGB 的计算公式: 1. 将 HSV 中的 S 和 V 值除以 100,得到范围在 0~1 之间的值。 2. 计算色相 H 在 RGB 中的值。如果 H 的范围在 0~60 或者 300~360 之间,则 R = V,G = (H/60)×V,B = 0。如果 H 的范围在 60~120 之间,则 R = ((120-H)/60)×V,G = V,B = 0。如果 H 的范围在 120~180 之间,则 R = 0,G = V,B =
recommend-type

JSBSim Reference Manual

JSBSim参考手册,其中包含JSBSim简介,JSBSim配置文件xml的编写语法,编程手册以及一些应用实例等。其中有部分内容还没有写完,估计有生之年很难看到完整版了,但是内容还是很有参考价值的。