about_Wildcards
Kort beskrivning
Beskriver hur du använder jokertecken i PowerShell.
Lång beskrivning
Jokertecken representerar ett eller flera tecken. Du kan använda dem för att skapa ordmönster i kommandon. Jokerteckenuttryck används med operatorn -like eller med någon parameter som accepterar jokertecken.
Om du till exempel vill matcha alla filer i C:\Techdocs katalogen med ett .ppt filnamnstillägg skriver du:
Get-ChildItem C:\Techdocs\*.ppt
I det här fallet representerar jokertecknet asterisk (*) alla tecken som visas före filnamnstillägget .ppt .
Jokerteckenuttryck är enklare än reguljära uttryck. Mer information finns i about_Regular_Expressions.
PowerShell stöder följande jokertecken:
| Jokertecken | Beskrivning | Exempel | Matchning | Ingen matchning |
|---|---|---|---|---|
* |
Matcha noll eller fler tecken | a* |
aA, ag, Apple | banan |
? |
Matcha ett tecken i den positionen | ?n |
an, in, on | rann |
[ ] |
Matcha ett teckenintervall | [a-l\]ook |
bok, kock, titta | intog |
[ ] |
Matcha specifika tecken | [bc]ook |
bok, kock | krok |
`* |
Matcha alla tecken som en literal (inte ett jokertecken) | 12`*4 |
12*4 | 1234 |
Du kan inkludera flera jokertecken i samma ordmönster. Om du till exempel vill hitta textfiler med namn som börjar med bokstäverna a till och med l skriver du:
Get-ChildItem C:\Techdocs\[a-l]*.txt
Det kan finnas fall där du vill matcha literaltecknet i stället för att behandla det som ett jokertecken. I dessa fall kan du använda backtick-tecknet (`) för att undvika jokertecknet så att det jämförs med literalteckenvärdet. Matchar till exempel '*hello`?*' strängar som innehåller "hello?".
Många cmdletar accepterar jokertecken i parametervärden. I hjälpavsnittet för varje cmdlet beskrivs vilka parametrar som accepterar jokertecken. För parametrar som accepterar jokertecken är deras användning skiftlägesokänslig.
Du kan använda jokertecken i kommandon och skriptblock, till exempel för att skapa ett ordmönster som representerar egenskapsvärden. Följande kommando hämtar till exempel tjänster där egenskapen ServiceType innehåller Interactive.
Get-Service | Where-Object {$_.ServiceType -Like "*Interactive*"}
I följande exempel innehåller -instruktionen If ett villkor som använder jokertecken för att hitta egenskapsvärden. Om återställningspunktens Beskrivning innehåller PowerShell lägger kommandot till värdet för återställningspunktens CreationTime-egenskap i en loggfil.
$p = Get-ComputerRestorePoint
foreach ($point in $p) {
if ($point.description -like "*PowerShell*") {
Add-Content -Path C:\TechDocs\RestoreLog.txt "$($point.CreationTime)"
}
}