Sdílet prostřednictvím


ConvertTo-Html

Převede objekty .NET na HTML, které lze zobrazit ve webovém prohlížeči.

Syntax

Page (Výchozí)

ConvertTo-Html
    [[-Property] <Object[]>]
    [[-Body] <String[]>]
    [[-Head] <String[]>]
    [[-Title] <String>]
    [-InputObject <PSObject>]
    [-As <String>]
    [-CssUri <Uri>]
    [-PostContent <String[]>]
    [-PreContent <String[]>]
    [-Meta <Hashtable>]
    [-Charset <String>]
    [-Transitional]
    [<CommonParameters>]

Fragment

ConvertTo-Html
    [[-Property] <Object[]>]
    [-InputObject <PSObject>]
    [-As <String>]
    [-Fragment]
    [-PostContent <String[]>]
    [-PreContent <String[]>]
    [<CommonParameters>]

Description

Rutina ConvertTo-Html převede objekty .NET na HTML, které lze zobrazit ve webovém prohlížeči. Tuto rutinu můžete použít k zobrazení výstupu příkazu na webové stránce.

Pomocí parametrů ConvertTo-Html můžete vybrat vlastnosti objektu, určit formát tabulky nebo seznamu, zadat název stránky HTML, přidat text před a za objekt a vrátit pouze fragment tabulky nebo seznamu místo striktní stránky DTD.

Když odešlete více objektů do ConvertTo-Html, PowerShell vytvoří tabulku (nebo seznam) na základě vlastností prvního objektu, který odešlete. Pokud zbývající objekty nemají jednu ze zadaných vlastností, hodnota vlastnosti tohoto objektu je prázdná buňka. Pokud zbývající objekty mají další vlastnosti, tyto hodnoty vlastností nejsou zahrnuty do souboru.

Příklady

Příklad 1: Vytvoření webové stránky pro zobrazení data

ConvertTo-Html -InputObject (Get-Date)

Tento příkaz vytvoří stránku HTML, která zobrazí vlastnosti aktuálního data. K odeslání výsledků příkazu do Get-Date rutiny používá parametr ConvertTo-Html.

Příklad 2: Vytvoření webové stránky pro zobrazení aliasů PowerShellu

Get-Alias | ConvertTo-Html | Out-File aliases.htm
Invoke-Item aliases.htm

Tento příkaz vytvoří stránku HTML se seznamem aliasů PowerShellu v aktuální konzole.

Příkaz používá rutinu Get-Alias k získání aliasů. Pomocí operátoru kanálu (|) odešle aliasy rutině ConvertTo-Html , která vytvoří stránku HTML. Příkaz také používá rutinu Out-File k odeslání kódu HTML do aliases.htm souboru.

Příklad 3: Vytvoření webové stránky pro zobrazení událostí PowerShellu

Get-EventLog -LogName "Windows PowerShell" | ConvertTo-Html | Out-File pslog.htm

Tento příkaz vytvoří stránku HTML s názvem pslog.htm , která zobrazí události v protokolu událostí Prostředí Windows PowerShell v místním počítači.

Pomocí rutiny Get-EventLog získá události v protokolu Windows PowerShellu a pak pomocí operátoru kanálu (|) odešle události do rutiny ConvertTo-Html . Příkaz také používá rutinu Out-File k odeslání kódu HTML do pslog.htm souboru.

Příkaz také používá rutinu Out-File k odeslání kódu HTML do pslog.htm souboru.

Příklad 4: Vytvoření webové stránky pro zobrazení procesů

Get-Process |
  ConvertTo-Html -Property Name, Path, Company -Title "Process Information" |
    Out-File proc.htm
Invoke-Item proc.htm

Tyto příkazy vytvoří a otevřou stránku HTML, která obsahuje název, cestu a společnost procesů v místním počítači.

První příkaz pomocí Get-Process rutiny získá objekty, které představují procesy spuštěné v počítači. Příkaz pomocí operátoru kanálu (|) odešle objekty procesu do rutiny ConvertTo-Html .

Příkaz používá parametr Vlastnost k výběru tří vlastností procesních objektů, které mají být zahrnuty do tabulky. Příkaz používá parametr Title k určení názvu stránky HTML. Příkaz také pomocí rutiny Out-File odešle výsledný kód HTML do souboru s názvem Proc.htm.

Druhý příkaz používá rutinu Invoke-ItemProc.htm k otevření ve výchozím prohlížeči.

Příklad 5: Vytvoření webové stránky pro zobrazení objektů služby

Get-Service | ConvertTo-Html -CssUri "test.css"
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN"  "https://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
<html>
<head>
<title>HTML TABLE</title>
<link rel="stylesheet" type="text/css" href="test.css" />
...

Tento příkaz vytvoří stránku HTML objektů služby, které rutina Get-Service vrátí. Příkaz používá parametr CssUri k určení šablony stylů CSS pro stránku HTML.

Parametr CssUri přidá do výsledného kódu HTML další <link rel="stylesheet" type="text/css" href="test.css"> značku. Atribut HREF ve značce obsahuje název šablony stylů.

Příklad 6: Vytvoření webové stránky pro zobrazení objektů služby

Get-Service | ConvertTo-Html -As LIST | Out-File services.htm

Tento příkaz vytvoří stránku HTML objektů služby, které rutina Get-Service vrátí. Příkaz používá parametr As k určení formátu seznamu. Out-File Rutina odešle výsledný kód HTML do Services.htm souboru.

Příklad 7: Vytvoření webové tabulky pro aktuální datum

Get-Date | ConvertTo-Html -Fragment
<table>
<colgroup>...</colgroup>
<tr><th>DisplayHint</th><th>DateTime</th><th>Date</th><th>Day</th><th>DayOfWeek</th><th>DayOfYear</th><th>Hour</th>
<th>Kind</th><th>Millisecond</th><th>Minute</th><th>Month</th><th>Second</th><th>Ticks</th><th>TimeOfDay</th><th>Year</th></tr>
<tr><td>DateTime</td><td>Monday, May 05, 2008 10:40:04 AM</td><td>5/5/2008 12:00:00 AM</td><td>5</td><td>Monday</td>
<td>126</td><td>10</td><td>Local</td><td>123</td><td>40</td><td>5</td><td>4</td><td>633455808041237213</td><td>10:40:04.12
37213</td><td>2008</td></tr>
</table>

Tento příkaz používá ConvertTo-Html k vygenerování tabulky HTML aktuálního data. Příkaz pomocí rutiny Get-Date získá aktuální datum. K odeslání výsledků do rutiny | používá operátor kanálu (ConvertTo-Html).

Příkaz ConvertTo-Html obsahuje parametr Fragment , který omezuje výstup na tabulku HTML. V důsledku toho jsou ostatní prvky stránky HTML, jako <HEAD> jsou například značky <BODY> , vynechány.

Příklad 8: Vytvoření webové stránky pro zobrazení událostí PowerShellu

Get-EventLog -Log "Windows PowerShell" | ConvertTo-Html -Property id, level, task

Tento příkaz používá rutinu Get-EventLog k získání událostí z protokolu událostí Windows PowerShellu.

Používá operátor kanálu (|) k odeslání událostí do ConvertTo-Html rutiny, která převádí události do formátu HTML.

Příkaz ConvertTo-Html používá parametr Property k výběru pouze vlastností ID, Úroveň a Úloha události.

Příklad 9: Vytvoření webové stránky pro zobrazení zadaných služeb

$htmlParams = @{
  Title = "Windows Services: Server01"
  Body = Get-Date
  PreContent = "<P>Generated by Corporate IT</P>"
  PostContent = "For details, contact Corporate IT."
}
Get-Service A* |
  ConvertTo-Html @htmlParams |
    Out-File Services.htm
Invoke-Item Services.htm

Tento příkaz vytvoří a otevře webovou stránku, která zobrazí služby v počítači, který začíná A. K přizpůsobení výstupu používá parametry Title, Body, PreContent a ConvertTo-Html.

První část příkazu používá rutinu Get-Service k získání služeb v počítači, který začíná A. Příkaz pomocí operátoru kanálu (|) odešle výsledky rutině ConvertTo-Html . Příkaz také používá rutinu Out-File k odeslání výstupu do Services.htm souboru.

Středník (;) ukončí první příkaz a spustí druhý příkaz, který pomocí rutiny Invoke-Item otevře Services.htm soubor ve výchozím prohlížeči.

Příklad 10: Nastavení vlastností meta a znakové sady HTML

Get-Service | ConvertTo-HTML -Meta @{
  refresh=10
  author="Author's Name"
  keywords="PowerShell, HTML, ConvertTo-HTML"
} -Charset "UTF-8"

Tento příkaz vytvoří html pro webovou stránku s metaznačky pro aktualizaci, autora a klíčová slova. Znaková sada pro stránku je nastavená na UTF-8.

Příklad 11: Nastavení html na XHTML přechodné DTD

Get-Service | ConvertTo-HTML -Transitional

Tento příkaz nastaví DOCTYPE vrácený kód HTML na XHTML Transitional DTD.

Parametry

-As

Určuje, zda je objekt formátován jako tabulka nebo seznam. Platné hodnoty jsou Tabulka a Seznam. Výchozí hodnota je Tabulka.

Hodnota Tabulka vygeneruje tabulku HTML, která se podobá formátu tabulky PowerShellu. Řádek záhlaví zobrazuje názvy vlastností. Každý řádek tabulky představuje objekt a zobrazuje hodnoty objektu pro každou vlastnost.

Hodnota List vygeneruje tabulku HTML se dvěma sloupci pro každý objekt, který se podobá formátu seznamu PowerShellu. První sloupec zobrazí název vlastnosti. Druhý sloupec zobrazí hodnotu vlastnosti.

Vlastnosti parametru

Typ:String
Default value:None
Přípustné hodnoty:Table, List
Podporuje zástupné znaky:False
DontShow:False

Sady parametrů

(All)
Position:Named
Povinné:False
Hodnota z kanálu:False
Hodnota z kanálu podle názvu vlastnosti:False
Hodnota ze zbývajících argumentů:False

-Body

Určuje text, který se má přidat za levou <BODY> značku. Ve výchozím nastavení není v této pozici žádný text.

Vlastnosti parametru

Typ:

String[]

Default value:None
Podporuje zástupné znaky:False
DontShow:False

Sady parametrů

Page
Position:3
Povinné:False
Hodnota z kanálu:False
Hodnota z kanálu podle názvu vlastnosti:False
Hodnota ze zbývajících argumentů:False

-Charset

Určuje text, který se má přidat do počáteční <charset> značky. Ve výchozím nastavení není v této pozici žádný text.

Tento parametr byl představen v PowerShellu 6.0.

Vlastnosti parametru

Typ:String
Default value:None
Podporuje zástupné znaky:False
DontShow:False

Sady parametrů

Page
Position:Named
Povinné:False
Hodnota z kanálu:False
Hodnota z kanálu podle názvu vlastnosti:False
Hodnota ze zbývajících argumentů:False

-CssUri

Určuje identifikátor URI (Uniform Resource Identifier) šablony stylů CSS (Cascading Style Sheet), který se použije u souboru HTML. Identifikátor URI je součástí odkazu šablony stylů ve výstupu.

Vlastnosti parametru

Typ:Uri
Default value:None
Podporuje zástupné znaky:False
DontShow:False
Aliasy:měď, URI

Sady parametrů

Page
Position:Named
Povinné:False
Hodnota z kanálu:False
Hodnota z kanálu podle názvu vlastnosti:False
Hodnota ze zbývajících argumentů:False

-Fragment

Generuje pouze tabulku HTML. Vynechá se hodnota <HTML>, <HEAD>, <TITLE>a <BODY> značky.

Vlastnosti parametru

Typ:SwitchParameter
Default value:None
Podporuje zástupné znaky:False
DontShow:False

Sady parametrů

Fragment
Position:Named
Povinné:False
Hodnota z kanálu:False
Hodnota z kanálu podle názvu vlastnosti:False
Hodnota ze zbývajících argumentů:False

-Head

Určuje obsah značky <HEAD> . Výchozí hodnota je <title\>HTML TABLE</title>. Pokud použijete parametr Head, bude parametr Title ignorován.

Vlastnosti parametru

Typ:

String[]

Default value:None
Podporuje zástupné znaky:False
DontShow:False

Sady parametrů

Page
Position:1
Povinné:False
Hodnota z kanálu:False
Hodnota z kanálu podle názvu vlastnosti:False
Hodnota ze zbývajících argumentů:False

-InputObject

Určuje objekty, které mají být reprezentovány v HTML. Zadejte proměnnou obsahující objekty nebo zadejte příkaz nebo výraz, který objekty získá.

Pokud tento parametr použijete k odeslání více objektů, například všech služeb v počítači, vytvoří tabulku, ConvertTo-Html která zobrazuje vlastnosti kolekce nebo pole objektů. Chcete-li vytvořit tabulku jednotlivých objektů, pomocí operátoru kanálu řaděte objekty do ConvertTo-Html.

Vlastnosti parametru

Typ:PSObject
Default value:None
Podporuje zástupné znaky:False
DontShow:False

Sady parametrů

(All)
Position:Named
Povinné:False
Hodnota z kanálu:True
Hodnota z kanálu podle názvu vlastnosti:False
Hodnota ze zbývajících argumentů:False

-Meta

Určuje text, který se má přidat do počáteční <meta> značky. Ve výchozím nastavení není v této pozici žádný text.

Tento parametr byl představen v PowerShellu 6.0.

Vlastnosti parametru

Typ:Hashtable
Default value:None
Podporuje zástupné znaky:False
DontShow:False

Sady parametrů

Page
Position:Named
Povinné:False
Hodnota z kanálu:False
Hodnota z kanálu podle názvu vlastnosti:False
Hodnota ze zbývajících argumentů:False

-PostContent

Určuje text, který se má přidat za pravou </TABLE> značku. Ve výchozím nastavení není v této pozici žádný text.

Vlastnosti parametru

Typ:

String[]

Default value:None
Podporuje zástupné znaky:False
DontShow:False

Sady parametrů

(All)
Position:Named
Povinné:False
Hodnota z kanálu:False
Hodnota z kanálu podle názvu vlastnosti:False
Hodnota ze zbývajících argumentů:False

-PreContent

Určuje text, který se má přidat před počáteční <TABLE> značku. Ve výchozím nastavení není v této pozici žádný text.

Vlastnosti parametru

Typ:

String[]

Default value:None
Podporuje zástupné znaky:False
DontShow:False

Sady parametrů

(All)
Position:Named
Povinné:False
Hodnota z kanálu:False
Hodnota z kanálu podle názvu vlastnosti:False
Hodnota ze zbývajících argumentů:False

-Property

Zahrnuje zadané vlastnosti objektů v HTML. Hodnota parametru Vlastnost může být nově vypočítaná vlastnost. Počítaná vlastnost může být blok skriptu nebo tabulka hash. Platné páry klíč-hodnota jsou:

  • Name (nebo popisek) – <string> (přidáno v PowerShellu 6.x)
  • Expression - <string> nebo <script block>
  • FormatString - <string>
  • Width - <int32> - musí být větší než 0
  • Alignment - hodnota může být Left, Centernebo Right

Další informace naleznete v dokumentaci about_Calculated_Properties.

Vlastnosti parametru

Typ:

Object[]

Default value:None
Podporuje zástupné znaky:False
DontShow:False

Sady parametrů

(All)
Position:0
Povinné:False
Hodnota z kanálu:False
Hodnota z kanálu podle názvu vlastnosti:False
Hodnota ze zbývajících argumentů:False

-Title

Určuje název souboru HTML, tj. text, který se zobrazí mezi <TITLE> značkami.

Vlastnosti parametru

Typ:String
Default value:None
Podporuje zástupné znaky:False
DontShow:False

Sady parametrů

Page
Position:2
Povinné:False
Hodnota z kanálu:False
Hodnota z kanálu podle názvu vlastnosti:False
Hodnota ze zbývajících argumentů:False

-Transitional

Změní přechod DOCTYPEXHTML DTD, výchozí DOCTYPE hodnota je XHTML Strict DTD.

Tento parametr byl představen v PowerShellu 6.0.

Vlastnosti parametru

Typ:SwitchParameter
Default value:None
Podporuje zástupné znaky:False
DontShow:False

Sady parametrů

Page
Position:Named
Povinné:False
Hodnota z kanálu:False
Hodnota z kanálu podle názvu vlastnosti:False
Hodnota ze zbývajících argumentů:False

CommonParameters

Tato rutina podporuje běžné parametry: -Debug, -ErrorAction, -ErrorVariable, -InformationAction, -InformationVariable, -OutBuffer, -OutVariable, -PipelineVariable, -ProgressAction, -Verbose, -WarningAction a -WarningVariable. Další informace najdete v about_CommonParameters.

Vstupy

PSObject

K tomuto cmdletu můžete přesměrovat libovolný objekt.

Výstupy

String

Tato rutina vrátí pole řetězců HTML představujících převedený objekt.

Poznámky

Chcete-li použít tuto rutinu, předaný jeden nebo více objektů do rutiny nebo použijte InputObject parametr k určení objektu. Když se vstup skládá z více objektů, výstup těchto dvou metod je poměrně odlišný.

  • Když do rutiny předáte více objektů, PowerShell odešle objekty do rutiny po jednom. V důsledku toho vytvoří tabulku, ConvertTo-Html která zobrazí jednotlivé objekty. Pokud například procesy v počítači ConvertTo-Htmlpředáte, zobrazí výsledná tabulka všechny procesy.

  • Když použijete parametr InputObject k odeslání více objektů, ConvertTo-Html obdrží tyto objekty jako kolekci nebo jako pole. V důsledku toho vytvoří tabulku, která zobrazí pole a její vlastnosti, nikoli položky v poli. Pokud například použijete InputObject k odeslání procesů v počítači do ConvertTo-Html, výsledná tabulka zobrazí pole objektů a jeho vlastnosti.

    Aby bylo v souladu s XHTML Strict DTD, DOCTYPE značka se odpovídajícím způsobem upraví:

    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd"\>