需要有关命令(如单线、powershell 删除文件夹)的帮助我正在尝试找到一种优雅的方法来按反映日期的文件夹名称删除文件夹,但我不能依赖文件/文件夹日期元数据属性。
这是我要解决的问题:我有一个文件夹,其中每天都有存档的通话录音,录音系统会创建文件夹并用通话录音填充它们,每天都有一个名为 format 的文件夹MM_dd_yyyy
。我需要删除除最后 7 个文件夹之外的所有文件夹。但是,我不能依赖文件上的创建/修改日期。仅使用 powershell 会容易得多。因此,不幸的是,我必须通过针对我需要以相同格式保留的文件夹的日期测试文件名来删除文件夹(MM_dd_yyyy)
。我可以使用以下 Windows 命令行获取基于前 6 天要保留的文件夹名称列表:
c:\>powershell $d0=(Get-Date).ToString('MM-dd-yyyy'); $d1=(Get-Date).AddDays(-1).ToString('MM-dd-yyyy'); $d2=(Get-Date).AddDays(-2).ToString('MM-dd-yyyy'); $d3=(Get-Date).AddDays(-3).ToString('MM-dd-yyyy'); $d4=(Get-Date).AddDays(-4).ToString('MM-dd-yyyy'); $d5=(Get-Date).AddDays(-5).ToString('MM-dd-yyyy'); $d6=(Get-Date).AddDays(-6).ToString('MM-dd-yyyy'); $d0; $d1; $d2; $d3; $d4; $d5; $d6
注意:由于公司和域强制执行的安全限制,我需要将其保存在单行命令中,并且不能使用 PS1 电源 shell 脚本
这会生成要保留的文件夹名称,如下所示(在 2021 年 11 月 20 日运行以保留最后 7 天)。
11_20_2021
11_19_2021
11_18_2021
11_17_2021
11_16_2021
11_15_2021
11_14_2021
目的是删除任何文件夹名称,例如 11_13_2021、11_12_2021... 等。
我可以在 Windows bat 文件中运行嵌套的 FOR 循环来尝试将其组合在一起,但我正在尝试找到一个更简单、可读和优雅的单行代码,它可以让我执行以下操作: powershell $d=(Get-Date).AddDays(-7).ToString('MM-dd-yyyy')
; 然后是一些神奇的 powershell 东西来删除任何与要保留的文件夹不匹配的文件夹。
如果我有办法为 powershell 命令提供文件夹名称(MM_dd_yyyy)
并(get-date).AddDays(-6)
让它返回布尔值是或否,那将更接近我正在寻找的东西。我一直在阅读,你在管和拔头发,但到目前为止我正在学习,但主要是把它弄得一团糟。任何想法都是最受欢迎的。
我很可能接近这一切都是错误的。约束是:
给定具有命名格式的文件夹列表MM_dd_yyyy
,我需要删除/删除所有不在最后一周内的文件夹。
我无法运行 powershell 脚本 .ps1 我可以运行带有 for 循环的 windows bat 或 cmd 文件,因此我不能依赖文件日期/时间元属性的文件夹,文件夹中的某些数据可能具有创建/写入/修改日期,而不是与文件夹名称一致。我必须依靠文件夹名称(MM_dd_yyyy)
来删除文件夹。
更新分辨率:
powershell "($f=Get-ChildItem -Path 'D:\PosConvSav' -Filter '*_*_*' -Directory | Where-Object { $_.Name -match '\d{2}_\d{2}_\d{4}' } | sort-object -desc)[14..($_.count)] | remove-item -recurse"