PowerShell получает обновленный HTML-отчет по Windows

0

У меня есть сценарий PowerShell, который получает прикладные обновления Windows с серверов 2003 года и выводит результат в отчет.HTML. Мне нравится помощь в том, как я могу получить каждое исправление для списка на отдельной строке вместо обернутого словами, как в приведенном ниже примере? Изображение 174551

Ниже приведен сценарий

$servers = Get-Content 'c:\temp\servers.txt'

$total = $null
$html = @'
<html>
<head>
<meta http-equiv='Content-Type' content='text/html; charset=iso-8859-1'>
<title> Server Updates Report</title>
<STYLE TYPE="text/css">
<!--
td {
font-family: Tahoma;
font-size: 13px;
border-top: 1px solid #999999;
border-right: 1px solid #999999;
border-bottom: 1px solid #999999;
border-left: 1px solid #999999;
padding-top: 0px;
padding-right: 0px;
padding-bottom: 0px;
padding-left: 0px;
}
body {
margin-left: 5px;
margin-top: 5px;
margin-right: 0px;
margin-bottom: 10px;

table {
border: thin solid #000000;
}
-->
</style>
</head>
<body>
<table width='100%'>
<tr bgcolor='#CCCCCC'>
<td colspan='7' height='25' align='center'><strong><font color="#003399" size="4"  face="tahoma">Server Patch Report </font></strong></td>
</tr>
</table>
<table width='100%'><tbody>
<tr bgcolor=#CCCCCC>
<td width='20%' height='15' align='center'> <strong> <font color="#003399" size="2" face="tahoma" >Server Name</font></strong></td>
<td width='80%' height='15' align='center'> <strong> <font color="#003399" size="2" face="tahoma" >Patching Information</font></strong></td>
</tr>" 
</table>
<table width='100%'><tbody>
'@

foreach($server in $servers){
    $date = Get-Date '24/10/2013'
    $Updates = gwmi win32_ntlogevent -filter "logfile='system' and sourcename='ntservicepack'" -ComputerName $server | Where {$_.ConvertToDateTime($_.TimeWritten) -gt $date} 

    $newobj = new-object psobject
    $newobj | add-member -membertype noteproperty -name "Server" -value $server 
    $newobj | add-member -membertype noteproperty -name "Updates" -value $Updates.Message 
    $htmlserver = $newobj.Server
    $htmlupdates = $newobj.Updates

$current = " <tr bgcolor=#CCCCCC>
<td width='20%' align='center'>$htmlserver</td>
<td width='80%' align='left'>$htmlupdates</td>
</tr> 
"     
$total += $current 
} 

$HTMLEnd = @"
</div>
</body>
</html>
"@

$MainHtml= $html + $total + $HTMLEnd
$MainHtml  | Out-File "c:\temp\Report.html" -Append
Теги:
powershell
report
updates

2 ответа

1
Лучший ответ

Я добавил цикл foreach, который проходит через каждое событие update и newobj код newobj который казался излишним. Это работает?

$servers = Get-Content 'c:\temp\servers.txt'

$total = $null
$html = @'
<html>
<head>
<meta http-equiv='Content-Type' content='text/html; charset=iso-8859-1'>
<title> Server Updates Report</title>
<STYLE TYPE="text/css">
<!--
td {
font-family: Tahoma;
font-size: 13px;
border-top: 1px solid #999999;
border-right: 1px solid #999999;
border-bottom: 1px solid #999999;
border-left: 1px solid #999999;
padding-top: 0px;
padding-right: 0px;
padding-bottom: 0px;
padding-left: 0px;
}
body {
margin-left: 5px;
margin-top: 5px;
margin-right: 0px;
margin-bottom: 10px;

table {
border: thin solid #000000;
}
-->
</style>
</head>
<body>
<table width='100%'>
<tr bgcolor='#CCCCCC'>
<td colspan='7' height='25' align='center'><strong><font color="#003399" size="4"  face="tahoma">Server Patch Report </font></strong></td>
</tr>
</table>
<table width='100%'><tbody>
<tr bgcolor=#CCCCCC>
<td width='20%' height='15' align='center'> <strong> <font color="#003399" size="2" face="tahoma" >Server Name</font></strong></td>
<td width='80%' height='15' align='center'> <strong> <font color="#003399" size="2" face="tahoma" >Patching Information</font></strong></td>
</tr>" 
</table>
<table width='100%'><tbody>
'@

foreach($server in $servers){
    $date = Get-Date '24/10/2013'
    gwmi win32_ntlogevent -filter "logfile='system' and sourcename='ntservicepack'" -ComputerName $server | Where {$_.ConvertToDateTime($_.TimeWritten) -gt $date} | ForEach-Object {

$current = " <tr bgcolor=#CCCCCC>
<td width='20%' align='center'>$server</td>
<td width='80%' align='left'>$($_.Message)</td>
</tr> 
"     
$total += $current 
} 
}
$HTMLEnd = @"
</div>
</body>
</html>
"@

$MainHtml= $html + $total + $HTMLEnd
$MainHtml  | Out-File "c:\temp\Report.html" -Append
  • 0
    Большое спасибо, что работа для примера я разместил :)
0

Взгляните на использование командлета ConvertTo-Html с помощью параметров -Fragment и -As LIST.

Если сообщения находятся в массиве, он преобразует его в HTML-код, который вы хотите

  • 0
    Спасибо, но это пример того, что мне нужно изменить, а не полный сценарий. Формат должен быть в качестве моего примера.

Ещё вопросы

Сообщество Overcoder
Наверх
Меню