JAVA实现删除某天之前的数据文件

public static void main(String[] args) {
        File file = new File(BackupConfig.backupPath);
        if(file.exists()) { //文件或文件夹是否存在
            if(file.isDirectory()) { //判断是不是目录
                info(file);
            }
        }
    }
    public static void info(File file) {
        //得到文件里面全部的文件及文件夹
        File[] files = file.listFiles();

        //遍历files里面的全部文件及文件夹
        for(File f : files) {
            //得到绝对路径下的文件及文件夹
            File absFile = f.getAbsoluteFile();

            //计算时间
            long day = 7;

            long hour = 24;

            long minute = 60;

            long second = 60;

            long mmcond = 1000;

            long currTime = System.currentTimeMillis(); //当前时间

            long lastTime = absFile.lastModified(); //文件被最后一次修改的时间

            //时间差

            long diffen = currTime - lastTime;

            // 定义指定天数删除时间
            long thDay = day * hour * minute * second * mmcond;

            if(diffen > 1000 * 60 * 5) { // 测试大于5分钟文件夹删除
                absFile.delete();

                if(absFile.isDirectory()) {
                    info(absFile);

                    absFile.delete();
                }
            }
        }
    }
  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
您可以使用以下Java代码来删除CSV文件中某一列数据的空值: ```java import java.io.BufferedReader; import java.io.BufferedWriter; import java.io.FileReader; import java.io.FileWriter; import java.io.IOException; public class CSVDataDeleter { public static void deleteEmptyValues(String csvFilePath, int columnIdx) { try (BufferedReader reader = new BufferedReader(new FileReader(csvFilePath)); BufferedWriter writer = new BufferedWriter(new FileWriter(csvFilePath + ".tmp"))) { String line; while ((line = reader.readLine()) != null) { String[] data = line.split(","); if (data.length > columnIdx && !data[columnIdx].isEmpty()) { writer.write(line); writer.newLine(); } } } catch (IOException e) { e.printStackTrace(); } // Rename the temporary file to original file String tempFilePath = csvFilePath + ".tmp"; String originalFilePath = csvFilePath; try { java.nio.file.Files.move(java.nio.file.Paths.get(tempFilePath), java.nio.file.Paths.get(originalFilePath), java.nio.file.StandardCopyOption.REPLACE_EXISTING); } catch (IOException e) { e.printStackTrace(); } } public static void main(String[] args) { String csvFilePath = "path/to/your/csv/file.csv"; int columnIdx = 2; // Index of the column with data to delete empty values deleteEmptyValues(csvFilePath, columnIdx); } } ``` 请将代码中的`csvFilePath`变量设置为您的CSV文件的路径,`columnIdx`变量设置为要删除空值的列的索引。 上述代码将会创建一个临时文件,在读取原始CSV文件时删除空值行,并将非空值行写入临时文件中。然后,它将删除原始文件并将临时文件重命名为原始文件的名称,从而替换原始文件。 请确保在运行代码之前备份您的原始CSV文件。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值