powershell - 按文件名Powershell中的日期列出文件
问题描述
我希望你一切都好。
我是 Powershell 的新手,我正在尝试制作一个脚本,允许根据文件名中的日期列出 7 天前的文件,然后将它们复制/移动到另一个目录。
文件结构:2020_06_11_DB.txt YYYY_MM_dd
我已经设置了这段脚本,但它只将文件与参考日期(DateRef)匹配,而不是它的最不(旧):
$SourceDB = "C:\DB\"
$DestinationDB = "C:\Destination\DB\"
$DateRef = Get-Date ((Get-Date).AddDays(-7)) -Format yyyy_MM_dd
$Query = Get-ChildItem $SourceDB -Filter "*$DateRef*" |
ForEach-object {
Copy-Item -Path $_.FullName -Destination $DestinationDB
}
我尝试了像 -le 和 -lt 这样的运算符,但没有成功。如果您能帮助我,我将不胜感激。
Get-ChildItem $SourceDB -Filter '*.txt' | Where-Object {$_.BaseName -le "*$DateRef*"}
谢谢!
解决方案
比较日期时,您需要使用DateTime
对象。所以挑战是从文件名中提取日期字符串并DateTime
在进行比较之前将它们转换为对象。
$SourceDB = "C:\DB\"
$DestinationDB = "C:\Destination\DB\"
$DateRef = (Get-Date).AddDays(-7).Date
$Query = Get-ChildItem $SourceDB -File | Where {
$_.BaseName -match '\d{4}_\d{2}_\d{2}' -and [datetime]::ParseExact(([regex]::Match($_.BaseName,'\d{4}_\d{2}_\d{2}').Value),'yyyy_MM_dd',$null) -le $DateRef } |
Foreach-Object {
Copy-Item -Path $_.FullName -Destination $DestinationDB
}
解释:
我不想阻止您使用-Filter
,因为它比在Where-Object
. 因此,您可以先使用类似-Filter '*_*_*'
或通配符的方式部分过滤 path -Path "$SourceDB*[0-9][0-9][0-9][0-9]_[0-9][0-9]_[0-9][0-9]*"
。
使用-File
参数 in Get-Childitem
,仅返回文件。
(Get-Date).AddDays(-7).Date
是今天前 7 天的午夜。
$_.BaseName -match '\d{4}_\d{2}_\d{2}'
匹配格式为####_##_##
.
[regex]::Match($_.BaseName,'\d{4}_\d{2}_\d{2}').Value
返回匹配的字符串####_##_##
。[datetime]::ParseExact()
将匹配的字符串(格式'yyyy_MM_dd')转换为DateTime
对象。
-le
小于或等于运算符。所以-le $DateRef
返回早于或等于的日期$DateRef
。
推荐阅读
- android - 未在 Android Studio 中使用 adb 触发广播接收器
- reactjs - NextJs 如何在用户离开页面时触发函数
- java - Arraylist .contains 方法是否适用于具有多个参数的 Arraylist
- c# - 如何将 ImageSource 绑定到 ObservableCollection 中特定元素的属性?
- python - 即使已安装,Odoo 也找不到 pandas 模块
- c# - OnSelectTemplate 可以为多个 CollectionViews 返回 DataTemplates 吗?Xamarin.Form C#
- angular - 如何将css分配给嵌入在Angular中的ts变量中的html
- docker - 使用 docker 在多个主机上启动弹性搜索
- python-3.x - 修补导入的类方法并断言如果调用一次
- mysql - 错误mysql:未知变量'ssl-mode = VERIFY_IDENTITY'使用证书连接到Mysql RDS