Measure-Object
Vypočítá číselné vlastnosti objektů a znaky, slova a řádky v řetězcových objektech, jako jsou soubory textu.
Syntaxe
Measure-Object
[-InputObject <PSObject>]
[[-Property] <String[]>]
[-Sum]
[-Average]
[-Maximum]
[-Minimum]
[<CommonParameters>]
Measure-Object
[-InputObject <PSObject>]
[[-Property] <String[]>]
[-Line]
[-Word]
[-Character]
[-IgnoreWhiteSpace]
[<CommonParameters>]
Description
Rutina Measure-Object
vypočítá hodnoty vlastností určitých typů objektů.
Measure-Object
provádí tři typy měření v závislosti na parametrech příkazu.
Rutina Measure-Object
provádí výpočty s hodnotami vlastností objektů. Pomocí Measure-Object
můžete spočítat objekty nebo spočítat objekty se zadaným Vlastnost. Pomocí Measure-Object
můžete také vypočítat minimální, maximální, součet, StandardDeviation a Průměrné číselných hodnot. Pro objekty String můžete také použít Measure-Object
ke spočítání počtu řádků, slov a znaků.
Příklady
Příklad 1: Počítání souborů a složek v adresáři
Tento příkaz spočítá soubory a složky v aktuálním adresáři.
Get-ChildItem | Measure-Object
Příklad 2: Měření souborů v adresáři
Tento příkaz zobrazí Minimální, Maximálnía Součet velikostí všech souborů v aktuálním adresáři a průměrnou velikost souboru v adresáři.
Get-ChildItem | Measure-Object -Property length -Minimum -Maximum -Average
Příklad 3: Měření textu v textovém souboru
Tento příkaz zobrazí počet znaků, slov a řádků v souboru Text.txt.
Bez parametru RawGet-Content
vypíše soubor jako pole řádků.
První příkaz používá Set-Content
k přidání výchozího textu do souboru.
"One", "Two", "Three", "Four" | Set-Content -Path C:\Temp\tmp.txt
Get-Content C:\Temp\tmp.txt | Measure-Object -Character -Line -Word
Lines Words Characters Property
----- ----- ---------- --------
4 4 15
Příklad 4: Měření objektů obsahujících zadanou vlastnost
Tento příklad spočítá počet objektů, které mají DisplayName vlastnost. První dva příkazy načítají všechny služby a procesy na místním počítači. Třetí příkaz spočítá kombinovaný počet služeb a procesů. Poslední příkaz kombinuje dvě kolekce a kanály výsledek Measure-Object
.
Objekt System.Diagnostics.Process nemá vlastnost DisplayName a je vynecháno z konečného počtu.
$services = Get-Service
$processes = Get-Process
$services + $processes | Measure-Object
$services + $processes | Measure-Object -Property DisplayName
Count : 682
Average :
Sum :
Maximum :
Minimum :
Property :
Count : 290
Average :
Sum :
Maximum :
Minimum :
Property : DisplayName
Příklad 5: Měření obsahu souboru CSV
Tento příkaz vypočítá průměrné roky služby zaměstnanců společnosti.
Soubor ServiceYrs.csv
je soubor CSV, který obsahuje počet zaměstnanců a roky služby každého zaměstnance. První řádek tabulky je řádek záhlaví EmpNo, Roky.
Pokud k importu souboru použijete Import-Csv
, výsledkem je PSCustomObject s poznámkami vlastnosti EmpNo a Years.
Pomocí Measure-Object
můžete vypočítat hodnoty těchto vlastností stejně jako jakoukoli jinou vlastnost objektu.
Import-Csv d:\test\serviceyrs.csv | Measure-Object -Property years -Minimum -Maximum -Average
Příklad 6: Měření logických hodnot
Tento příklad ukazuje, jak Measure-Object
může měřit logické hodnoty.
V tomto případě používá PSIsContainerBoolean vlastnost k měření výskytu složek (vs. souborů) v aktuálním adresáři.
Get-ChildItem | Measure-Object -Property psiscontainer -Maximum -Sum -Minimum -Average
Count : 126
Average : 0.0634920634920635
Sum : 8
Maximum : 1
Minimum : 0
StandardDeviation :
Property : PSIsContainer
Příklad 7: Řetězce měr
Následující příklad měří počet řádků, nejprve jeden řetězec a pak napříč několika řetězci. Znak nového řádku `n
odděluje řetězce do více řádků.
# The newline character `n separates the string into separate lines, as shown in the output.
"One`nTwo`nThree"
"One`nTwo`nThree" | Measure-Object -Line
One
Two
Three
Lines Words Characters Property
----- ----- ---------- --------
3
# The first string counts as a single line.
# The second string is separated into two lines by the newline character.
"One", "Two`nThree" | Measure-Object -Line
Lines Words Characters Property
----- ----- ---------- --------
3
# The Word switch counts the number of words in each InputObject
# Each InputObject is treated as a single line.
"One, Two", "Three", "Four Five" | Measure-Object -Word -Line
Lines Words Characters Property
----- ----- ---------- --------
3 5
Parametry
-Average
Označuje, že rutina zobrazuje průměrnou hodnotu zadaných vlastností.
Typ: | SwitchParameter |
Position: | Named |
Default value: | None |
Vyžadováno: | False |
Přijmout vstup kanálu: | False |
Přijmout zástupné znaky: | False |
-Character
Označuje, že rutina spočítá počet znaků ve vstupních objektech.
Poznámka
Word, Char a Line přepne počet uvnitř každého vstupního objektu a také napříč vstupními objekty. Viz příklad 7.
Typ: | SwitchParameter |
Position: | Named |
Default value: | None |
Vyžadováno: | False |
Přijmout vstup kanálu: | False |
Přijmout zástupné znaky: | False |
-IgnoreWhiteSpace
Označuje, že rutina ignoruje prázdné znaky v počtu znaků. Ve výchozím nastavení není prázdné znaky ignorovány.
Typ: | SwitchParameter |
Position: | Named |
Default value: | False |
Vyžadováno: | False |
Přijmout vstup kanálu: | False |
Přijmout zástupné znaky: | False |
-InputObject
Určuje objekty, které se mají měřit. Zadejte proměnnou, která obsahuje objekty, nebo zadejte příkaz nebo výraz, který objekty získá.
Pokud použijete InputObject parametr s Measure-Object
, místo piping command results to Measure-Object
, InputObject hodnota je považována za jeden objekt.
Pokud chcete měřit kolekci objektů na základě toho, zda mají objekty určité hodnoty v definovaných vlastnostech, doporučujeme použít Measure-Object
v kanálu.
Typ: | PSObject |
Position: | Named |
Default value: | None |
Vyžadováno: | False |
Přijmout vstup kanálu: | True |
Přijmout zástupné znaky: | False |
-Line
Označuje, že rutina spočítá počet řádků ve vstupních objektech.
Poznámka
Word, Char a Line přepne počet uvnitř každého vstupního objektu a také napříč vstupními objekty. Viz příklad 7.
Typ: | SwitchParameter |
Position: | Named |
Default value: | False |
Vyžadováno: | False |
Přijmout vstup kanálu: | False |
Přijmout zástupné znaky: | False |
-Maximum
Označuje, že rutina zobrazuje maximální hodnotu zadaných vlastností.
Typ: | SwitchParameter |
Position: | Named |
Default value: | False |
Vyžadováno: | False |
Přijmout vstup kanálu: | False |
Přijmout zástupné znaky: | False |
-Minimum
Označuje, že rutina zobrazí minimální hodnotu zadaných vlastností.
Typ: | SwitchParameter |
Position: | Named |
Default value: | False |
Vyžadováno: | False |
Přijmout vstup kanálu: | False |
Přijmout zástupné znaky: | False |
-Property
Určuje jednu nebo více vlastností, které se mají měřit. Pokud nezadáte žádné jiné míry, Measure-Object
spočítá objekty, které mají zadané vlastnosti.
Typ: | String[] |
Position: | 0 |
Default value: | None |
Vyžadováno: | False |
Přijmout vstup kanálu: | False |
Přijmout zástupné znaky: | True |
-Sum
Označuje, že rutina zobrazí součet hodnot zadaných vlastností.
Typ: | SwitchParameter |
Position: | Named |
Default value: | False |
Vyžadováno: | False |
Přijmout vstup kanálu: | False |
Přijmout zástupné znaky: | False |
-Word
Označuje, že rutina spočítá počet slov ve vstupních objektech.
Poznámka
Word, Char a Line přepne počet uvnitř každého vstupního objektu a také napříč vstupními objekty. Viz příklad 7.
Typ: | SwitchParameter |
Position: | Named |
Default value: | False |
Vyžadováno: | False |
Přijmout vstup kanálu: | False |
Přijmout zástupné znaky: | False |
Vstupy
Objekty můžete pipetovat do Measure-Object
.
Výstupy
Microsoft.PowerShell.Commands.GenericMeasureInfo, Microsoft.PowerShell.Commands.TextMeasureInfo, Microsoft.PowerShell.Commands.GenericObjectMeasureInfo
Pokud použijete parametr Word, Measure-Object
vrátí objekt TextMeasureInfo.
V opačném případě vrátí GenericMeasureInfo objektu.