PowerShell: параметры функции
-
12-12-2019 - |
Вопрос
Я создаю функцию PowerShell, чтобы я мог запрашивать журналы событий нескольких компьютеров.IVe скопировал код ниже, с которым мне нужна помощь.Если я не отправлю eventiD, я хочу, чтобы скрипт нашел все идентификаторы события, как я могу добиться этого?
#this would be the parameter part of the script
[String]$ComputerName = $env:COMPUTERNAME#Current computer
[String[]]$EventLogNames=@("Application","System")#Main eventlogs
[int[]]$EventIds = 1 #Event Ids
[System.DateTime[]]$EventStartDate = (((Get-Date).addDays(-2)).date)#date 10 days ago
[System.DateTime[]]$EventEndTime = (Get-Date)#date 10 days ago
#This fits in the process section
$EventCritea = @{logname = $EventLogNames; StartTime=$EventStartDate; EndTime=$EventEndTime; ID=$EventIds}
Get-WinEvent -ComputerName $ComputerName -FilterHashTable $EventCritea -ErrorAction SilentlyContinue
. Решение
Первый, ваш другой Вопрос исправляетТипы $EventStartDate
и $EventEndTime
.
Для этого вопроса: построить hashtable постепенно:
$filter = @{logname = $EventLogNames; StartTime=$EventStartDate; EndTime=$EventEndTime}
if ($EventIds -ne $null -and $EventIds.Length -gt 0) {
$filter.ID=$EventIds
}
Get-WinEvent -ComputerName $ComputerName -FilterHashTable $filter #...
. Не связан с StackOverflow