【问题标题】:Get-WinEvent Script获取 WinEvent 脚本
【发布时间】:2020-04-16 17:29:44
【问题描述】:

我有一个按预期工作的 powershell 脚本。我需要一些帮助来格式化输出。

$Date = (Get-Date).AddDays(-1)
Get-ChildItem –Path "D:\Log\" -Recurse | Where-Object {($_.LastWriteTime -lt $Date)} | Remove-Item
$filter = @{
LogName='Application'
StartTime=$Date
}
Get-WinEvent -FilterHashtable $filter | Select-Object TimeCreated,Message | 
Where-Object { $_.Message -like '*renamed*' -and $_.Message -notlike "*csv*" } |
Out-File -FilePath D:\Log\DailyReport_$(get-date -Format yyyyddmm_hhmmtt).txt

输出是

TimeCreated          Message                                                                                                                             
-----------          -------                                                                                                                             
4/16/2020 4:03:30 AM 04712: renamed

我需要输出是

Date Time,File Name

4/16/2020 4:03:30 AM, 04712: renamed

列标题需要用逗号重命名。任何帮助将不胜感激。

谢谢,

阿纳布

【问题讨论】:

    标签: powershell get-winevent


    【解决方案1】:

    您可以使用Select-Object 重命名属性,并使用ConvertTo-CsvExport-Csv 转换为逗号分隔值:

    # ...
    Get-WinEvent -FilterHashtable $filter |
      Select-Object TimeCreated,Message |
      Where-Object { $_.Message -like '*renamed*' -and $_.Message -notlike "*csv*" } |
      Select-Object @{Name='Date Time';Expression='TimeCreated'},@{Name='File Name';Expression='Message'} |
      Export-Csv D:\Log\DailyReport_$(get-date -Format yyyyddmm_hhmmtt).txt -NoTypeInformation
    

    【讨论】:

    • 谢谢 Mathias,由于 Export-csv,有什么方法可以删除引号。其他一切看起来都很完美。
    猜你喜欢
    • 1970-01-01
    • 2016-09-15
    • 2016-09-10
    • 2021-07-30
    • 1970-01-01
    • 2011-05-22
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多