首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Get-WinEvent脚本

Get-WinEvent脚本
EN

Stack Overflow用户
提问于 2020-04-17 01:29:44
回答 1查看 94关注 0票数 0

我有一个powershell脚本,它可以像预期的那样工作。我需要一些帮助来格式化输出。

代码语言:javascript
复制
$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

输出为

代码语言:javascript
复制
TimeCreated          Message                                                                                                                             
-----------          -------                                                                                                                             
4/16/2020 4:03:30 AM 04712: renamed

我需要的输出是

代码语言:javascript
复制
Date Time,File Name

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

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

谢谢,

Arnab

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2020-04-17 01:41:26

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

代码语言:javascript
复制
# ...
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
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/61256363

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档