Powershell - Szybki przewodnik
Windows PowerShell to command-line shell i scripting languagezaprojektowany specjalnie do administrowania systemem. W Linuksie jego odpowiednik nazywa się Bash Scripting. Zbudowany na platformie .NET Framework program Windows PowerShell pomaga informatykom kontrolować i automatyzować administrowanie systemem operacyjnym Windows oraz aplikacjami działającymi w środowisku Windows Server.
Polecenia programu Windows PowerShell o nazwie cmdlets, pozwalają zarządzać komputerami z wiersza poleceń. Dostawcy programu Windows PowerShell umożliwiają dostęp do magazynów danych, takich jak Rejestr i Magazyn certyfikatów, równie łatwo, jak do systemu plików.
Ponadto Windows PowerShell ma bogaty parser wyrażeń i w pełni rozwinięty język skryptowy. Więc w prostych słowach możesz wykonać wszystkie zadania, które wykonujesz za pomocą GUI i wiele więcej.
PowerShell ISE
Windows PowerShell Integrated Scripting Environment(ISE) to aplikacja hosta dla programu Windows PowerShell. W programie Windows PowerShell ISE można uruchamiać polecenia oraz pisać, testować i debugować skrypty w jednym graficznym interfejsie użytkownika opartym na systemie Windows z edycją wielowierszową, uzupełnianiem tabulatorów, kolorowaniem składni, wykonywaniem wybiórczym, pomocą kontekstową i obsługą praw do - języki lewe.
Za pomocą elementów menu i skrótów klawiaturowych można wykonywać wiele takich samych zadań, które można wykonywać w konsoli programu Windows PowerShell. Na przykład podczas debugowania skryptu w środowisku Windows PowerShell ISE, aby ustawić punkt przerwania wiersza w skrypcie, kliknij prawym przyciskiem myszy wiersz kodu, a następnie kliknijToggle Breakpoint.
Podstawowe polecenia programu PowerShell
Istnieje wiele poleceń PowerShell i bardzo trudno jest umieścić je we wszystkich tych poleceniach w tym samouczku, skupimy się na niektórych z najważniejszych, a także na podstawowych poleceniach PowerShell.
Pierwszym krokiem jest przejście do polecenia Get-Help, które zawiera wyjaśnienie, jak podać polecenie i jego parametr.
Ikonę PowerShell można znaleźć na pasku zadań oraz w menu Start. Wystarczy kliknąć ikonę, aby się otworzyć.
Aby go otworzyć, wystarczy kliknąć ikonę, a następnie otworzy się następujący ekran i oznacza to, że PowerShell jest gotowy do pracy.
Wersja programu PowerShell
Najnowsza wersja PowerShell to 5.0 i aby sprawdzić, co jest zainstalowane na naszym serwerze, wpisujemy następujące polecenie - :$PSVersionTable jak pokazano na poniższym zrzucie ekranu, az ekranu wiemy również, że mamy PSVersion 4.0
Aby zaktualizować do najnowszej wersji, w której ma więcej poleceń cmdlet, musimy pobrać Windows Management Framework 5.0 z poniższego linku - https://www.microsoft.com/en-us/download/details.aspx?id=50395 i zainstaluj.
PowerShell ISE
Windows PowerShell Integrated Scripting Environment(ISE) to aplikacja hosta dla programu Windows PowerShell. W programie Windows PowerShell ISE można uruchamiać polecenia oraz pisać, testować i debugować skrypty w jednym graficznym interfejsie użytkownika opartym na systemie Windows z edycją wielowierszową, uzupełnianiem tabulatorów, kolorowaniem składni, wykonywaniem wybiórczym, pomocą kontekstową i obsługą praw do - języki lewe.
Za pomocą elementów menu i skrótów klawiaturowych można wykonywać wiele takich samych zadań, które można wykonywać w konsoli programu Windows PowerShell. Na przykład podczas debugowania skryptu w środowisku Windows PowerShell ISE, aby ustawić punkt przerwania wiersza w skrypcie, kliknij prawym przyciskiem myszy wiersz kodu, a następnie kliknijToggle Breakpoint.
Aby go otworzyć, po prostu przejdź do Start - Wyszukaj, a następnie wpisz - PowerShell, jak pokazano na poniższym zrzucie ekranu.
Następnie kliknij Windows PowerShell ISE. Lub kliknij strzałkę w dół, jak pokazano na poniższym zrzucie ekranu.
Wyświetli listę wszystkich aplikacji zainstalowanych na serwerze, a następnie kliknie Windows PowerShell ISE.
Następująca tabela będzie otwarta -
Ma trzy sekcje, które obejmują - PowerShell Console z numerem 1 Scripting File numer 2, a trzeci to Command Module gdzie można znaleźć moduł.
Podczas tworzenia skryptu możesz uruchomić go bezpośrednio i zobaczyć wynik, jak na poniższym przykładzie -
Podstawowe polecenia programu PowerShell
Istnieje wiele poleceń PowerShell i bardzo trudno jest umieścić je we wszystkich tych poleceniach w tym samouczku, skupimy się na niektórych z najważniejszych, a także na podstawowych poleceniach PowerShell.
Pierwszym krokiem jest przejście do polecenia Get-Help, które zawiera wyjaśnienie, jak podać polecenie i jego parametr.
To get the list of Updates -
- Get-HotFix i zainstaluj poprawkę w następujący sposób
- Pobierz-HotFix -id kb2741530
Polecenie cmdlet lub „Command let” to lekkie polecenie używane w środowisku Windows PowerShell. Środowisko wykonawcze programu Windows PowerShell wywołuje te polecenia cmdlet w wierszu polecenia. Można je tworzyć i wywoływać programowo za pomocą interfejsów API programu Windows PowerShell.
Cmdlet vs Command
Polecenia cmdlet znacznie różnią się od poleceń w innych środowiskach powłoki poleceń w następujący sposób:
Polecenia cmdlet to obiekty klasy .NET Framework; a nie tylko samodzielne pliki wykonywalne.
Polecenia cmdlet można łatwo zbudować z zaledwie kilkunastu wierszy kodu.
Parsowanie, prezentacja błędów i formatowanie danych wyjściowych nie są obsługiwane przez polecenia cmdlet. Jest to realizowane przez środowisko wykonawcze Windows PowerShell.
Proces poleceń cmdlet działa na obiektach poza strumieniem tekstowym, a obiekty mogą być przekazywane jako dane wyjściowe do przetwarzania potokowego.
Polecenia cmdlet są oparte na rekordach, ponieważ przetwarzają jeden obiekt naraz.
Otrzymywać pomoc
Pierwszym krokiem jest przejście do polecenia Get-Help, które zawiera wyjaśnienie, jak podać polecenie i jego parametr.
Poniżej znajdują się przykłady skryptów PowerShell w plikach i folderach.
Sr.No. | Opis operacji |
---|---|
1 |
Tworzenie folderów
Przykładowy skrypt pokazujący, jak tworzyć foldery za pomocą skryptów PowerShell. |
2 |
Tworzenie plików
Przykładowy skrypt pokazujący, jak tworzyć pliki za pomocą skryptów PowerShell. |
3 |
Kopiowanie folderów
Przykładowy skrypt pokazujący, jak skopiować plik (i) za pomocą skryptów PowerShell. |
4 |
Kopiowanie plików
Przykładowy skrypt pokazujący, jak tworzyć pliki za pomocą skryptów PowerShell. |
5 |
Usuwanie folderów
Przykładowy skrypt pokazujący, jak usunąć foldery za pomocą skryptów PowerShell. |
6 |
Usuwanie plików
Przykładowy skrypt pokazujący, jak usunąć plik (i) za pomocą skryptów PowerShell. |
7 |
Przenoszenie folderów
Przykładowy skrypt pokazujący, jak przenosić foldery za pomocą skryptów PowerShell. |
8 |
Przenoszenie plików
Przykładowy skrypt pokazujący, jak przenieść plik (i) za pomocą skryptów PowerShell. |
9 |
Zmień nazwy folderów
Przykładowy skrypt pokazujący, jak zmienić nazwy folderów za pomocą skryptów PowerShell. |
10 |
Zmień nazwy plików
Przykładowy skrypt pokazujący, jak zmienić nazwę pliku (plików) za pomocą skryptów PowerShell. |
11 |
Odzyskiwanie przedmiotu
Przykładowy skrypt pokazujący, jak pobrać elementy za pomocą skryptów PowerShell. |
12 |
Sprawdź istnienie folderu
Przykładowy skrypt pokazujący, jak sprawdzić istnienie folderu za pomocą skryptów PowerShell. |
13 |
Sprawdź istnienie pliku
Przykładowy skrypt pokazujący, jak sprawdzić istnienie pliku za pomocą skryptów PowerShell. |
Poniżej znajdują się przykłady skryptów PowerShell dotyczących daty i godziny systemowej.
Sr.No. | Opis operacji |
---|---|
1 |
Pobierz datę systemową
Przykładowy skrypt pokazujący, jak uzyskać datę systemową za pomocą skryptów PowerShell. |
2 |
Ustaw datę systemową
Przykładowy skrypt pokazujący, jak ustawić datę systemową za pomocą skryptów PowerShell. |
3 |
Uzyskaj czas systemowy
Przykładowy skrypt pokazujący, jak uzyskać czas systemowy za pomocą skryptów PowerShell. |
4 |
Ustaw czas systemowy
Przykładowy skrypt pokazujący, jak ustawić czas systemowy za pomocą skryptów PowerShell. |
Poniżej znajdują się przykłady skryptów PowerShell służących do tworzenia i odczytywania różnych typów plików.
Sr.No. | Opis operacji |
---|---|
1 |
Utwórz plik tekstowy
Przykładowy skrypt, aby pokazać, jak utworzyć plik tekstowy za pomocą skryptów PowerShell. |
2 |
Czytaj plik tekstowy
Przykładowy skrypt, aby pokazać, jak odczytać plik tekstowy za pomocą skryptów PowerShell. |
3 |
Utwórz plik XML
Przykładowy skrypt, aby pokazać, jak utworzyć plik XML za pomocą skryptów PowerShell. |
4 |
Przeczytaj plik XML
Przykładowy skrypt pokazujący, jak odczytać plik XML za pomocą skryptów PowerShell. |
5 |
Utwórz plik CSV
Przykładowy skrypt pokazujący, jak utworzyć plik CSV przy użyciu skryptów PowerShell. |
6 |
Przeczytaj plik CSV
Przykładowy skrypt, aby pokazać, jak odczytać plik CSV za pomocą skryptów PowerShell. |
7 |
Utwórz plik HTML
Przykładowy skrypt, aby pokazać, jak utworzyć plik HTML za pomocą skryptów PowerShell. |
8 |
Przeczytaj plik HTML
Przykładowy skrypt pokazujący, jak odczytać plik HTML za pomocą skryptów PowerShell. |
9 |
Kasowanie zawartości pliku
Przykładowy skrypt, aby pokazać, jak usunąć zawartość pliku za pomocą skryptów PowerShell. |
10 |
Dołącz dane tekstowe
Przykładowy skrypt, aby pokazać, jak dołączyć tekst do zawartości pliku za pomocą skryptów PowerShell. |
Polecenia cmdlet
Polecenie cmdlet lub „Command let” to lekkie polecenie używane w środowisku Windows PowerShell. Środowisko wykonawcze programu Windows PowerShell wywołuje te polecenia cmdlet w wierszu polecenia. Można je tworzyć i wywoływać programowo za pomocą interfejsów API programu Windows PowerShell. Poniżej przedstawiono przykład zaawansowanego użycia poleceń cmdlet.
Sr.No. | Typ i opis polecenia cmdlet |
---|---|
1 |
Polecenie cmdlet Get-Unique
Przykładowy program do prezentacji polecenia cmdlet Get-Unique. |
2 |
Group-Object Cmdlet Przykładowy program do prezentacji polecenia cmdlet Group-Object. |
3 |
Polecenie cmdlet Measure-Object
Przykładowy program do prezentacji polecenia cmdlet Measure-Object. |
4 |
Polecenie cmdlet Compare-Object
Przykładowy program do zaprezentowania polecenia cmdlet Compare-Object. |
5 |
Polecenie cmdlet listy formatów
Przykładowy program do prezentacji polecenia cmdlet listy formatów. |
6 |
Polecenie cmdlet dla całego formatu
Przykładowy program do prezentacji polecenia cmdlet dla całego formatu. |
7 |
Polecenie cmdlet obiektu Where-Object
Przykładowy program do prezentacji polecenia Where-Object Cmdlet. |
8 |
Polecenie cmdlet Get-ChildItem
Przykładowy program do prezentacji polecenia cmdlet Get-ChildItem. |
9 |
Polecenie cmdlet ForEach-Object
Przykładowy program do prezentacji polecenia cmdlet ForEach-Object. |
10 |
Polecenie cmdlet Start-Sleep
Przykładowy program do prezentacji polecenia cmdlet Start-Sleep. |
11 |
Polecenie cmdlet odczytu hosta
Przykładowy program do prezentacji polecenia cmdlet Read-Host. |
12 |
Polecenie cmdlet Select-Object
Przykładowy program do prezentacji polecenia cmdlet Select-Object. |
13 |
Polecenie cmdlet obiektu sortowania
Przykładowy program do prezentacji polecenia Sort-Object Cmdlet. |
14 |
Polecenie cmdlet ostrzeżenia o zapisie
Przykładowy program do prezentacji polecenia cmdlet Write-Warning. |
15 |
Polecenie cmdlet Write-Host
Przykładowy program do prezentacji polecenia cmdlet Write-Host. |
16 |
Polecenie cmdlet Invoke-Item
Przykładowy program do prezentacji polecenia cmdlet Invoke-Item. |
17 |
Polecenie cmdlet Invoke-Expression
Przykładowy program do prezentacji polecenia cmdlet Invoke-Expression. |
18 |
Polecenie cmdlet polecenia Measure-Command
Przykładowy program do prezentacji polecenia cmdlet Measure-Command. |
19 |
Polecenie cmdlet Invoke-History
Przykładowy program do prezentacji polecenia cmdlet Invoke-History. |
20 |
Polecenie cmdlet historii dodawania
Przykładowy program do prezentacji polecenia cmdlet historii dodawania. |
21 |
Polecenie cmdlet Get-History
Przykładowy program do prezentacji polecenia cmdlet Get-History. |
22 |
Polecenie cmdlet Get-Culture
Przykładowy program do prezentacji polecenia cmdlet Get-Culture. |
Windows PowerShell to command-line shell i scripting languagezaprojektowany specjalnie do administrowania systemem. Jego odpowiednik w Linuksie nosi nazwę Bash Scripting. Zbudowany na platformie .NET Framework program Windows PowerShell pomaga informatykom kontrolować i automatyzować administrowanie systemem operacyjnym Windows oraz aplikacjami działającymi w środowisku Windows Server.
Polecenia programu Windows PowerShell o nazwie cmdlets, pozwalają zarządzać komputerami z wiersza poleceń. Dostawcy programu Windows PowerShell umożliwiają dostęp do magazynów danych, takich jak Rejestr i Magazyn certyfikatów, równie łatwo, jak do systemu plików.
Ponadto Windows PowerShell ma bogaty parser wyrażeń i w pełni rozwinięty język skryptowy. Więc w prostych słowach możesz wykonać wszystkie zadania, które wykonujesz za pomocą GUI i wiele więcej. Windows PowerShell Scripting jest w pełni rozwiniętym językiem skryptowym i ma bogaty parser wyrażeń /
funkcje
Cmdlets - Polecenia cmdlet wykonują typowe zadania administracyjne, takie jak zarządzanie rejestrem, usługami, procesami, dziennikami zdarzeń i korzystanie z Instrumentacji zarządzania Windows (WMI).
Task oriented - Język skryptowy PowerShell jest oparty na zadaniach i zapewnia obsługę istniejących skryptów i narzędzi wiersza polecenia.
Consistent design- Ponieważ polecenia cmdlet i systemowe magazyny danych używają wspólnej składni i mają wspólne konwencje nazewnictwa, udostępnianie danych jest łatwe. Dane wyjściowe z jednego polecenia cmdlet można przesłać potokiem do innego polecenia bez żadnej manipulacji.
Simple to Use - Uproszczona nawigacja oparta na poleceniach pozwala użytkownikom poruszać się po rejestrze i innych magazynach danych podobnych do nawigacji w systemie plików.
Object based- PowerShell posiada potężne możliwości manipulacji obiektami. Obiekty można przesyłać bezpośrednio do innych narzędzi lub baz danych.
Extensible interface. - PowerShell można dostosować, ponieważ niezależni dostawcy oprogramowania i programiści korporacyjni mogą tworzyć niestandardowe narzędzia i narzędzia za pomocą PowerShell do administrowania swoim oprogramowaniem.
Zmienne
Zmienne programu PowerShell są nazwanymi obiektami. Ponieważ PowerShell działa z obiektami, te zmienne są używane do pracy z obiektami.
Tworzenie zmiennej
Nazwa zmiennej powinna zaczynać się od znaku $ i może zawierać znaki alfanumeryczne oraz podkreślenie w nazwie. Zmienną można utworzyć, wpisując prawidłową nazwę zmiennej.
Wpisz następujące polecenie w konsoli PowerShell ISE. Zakładając, że jesteś w folderze D: \ test.
$location = Get-Location
Tutaj utworzyliśmy zmienną $ location i przypisaliśmy jej wynik polecenia cmdlet Get-Location. Zawiera teraz aktualną lokalizację.
Korzystanie ze zmiennej
Wpisz następujące polecenie w konsoli PowerShell ISE.
$location
Wynik
Możesz zobaczyć następujące dane wyjściowe w konsoli programu PowerShell.
Path
----
D:\test
Pobieranie informacji o zmiennej
Polecenie cmdlet Get-Member może określić typ używanej zmiennej. Zobacz poniższy przykład.
$location | Get-Member
Wynik
Możesz zobaczyć następujące dane wyjściowe w konsoli programu PowerShell.
TypeName: System.Management.Automation.PathInfo
Name MemberType Definition
---- ---------- ----------
Equals Method bool Equals(System.Object obj)
GetHashCode Method int GetHashCode()
GetType Method type GetType()
ToString Method string ToString()
Drive Property System.Management.Automation.PSDriveInfo Drive {get;}
Path Property System.String Path {get;}
Provider Property System.Management.Automation.ProviderInfo Provider {get;}
ProviderPath Property System.String ProviderPath {get;}
Zmienne specjalne programu PowerShell przechowują informacje o programie PowerShell. Nazywa się je również zmiennymi automatycznymi. Poniżej znajduje się lista automatycznych zmiennych -
Operator | Opis |
---|---|
$$ | Reprezentuje ostatni token w ostatniej linii odebrany przez sesję. |
$? | Reprezentuje stan wykonania ostatniej operacji. Zawiera TRUE, jeśli ostatnia operacja się powiodła i FALSE, jeśli się nie powiodła. |
$ ^ | Reprezentuje pierwszy token w ostatniej linii odebranej przez sesję. |
$ _ | To samo co $ PSItem. Zawiera bieżący obiekt w obiekcie potoku. Tej zmiennej można używać w poleceniach, które wykonują akcję na każdym obiekcie lub na wybranych obiektach w potoku. |
$ ARGS | Reprezentuje tablicę niezadeklarowanych parametrów i / lub wartości parametrów, które są przesyłane do bloku funkcji, skryptu lub skryptu. |
$ CONSOLEFILENAME | Reprezentuje ścieżkę do pliku konsoli (.psc1), który był ostatnio używany w sesji. |
$ ERROR | Reprezentuje tablicę obiektów błędów, które reprezentują najnowsze błędy. |
$ EVENT | Reprezentuje obiekt PSEventArgs, który reprezentuje zdarzenie, które jest przetwarzane. |
$ EVENTARGS | Reprezentuje obiekt, który reprezentuje pierwszy argument zdarzenia pochodzący z EventArgs zdarzenia, które jest przetwarzane. |
$ EVENTSUBSCRIBER | Reprezentuje obiekt PSEventSubscriber, który reprezentuje subskrybenta zdarzenia przetwarzanego zdarzenia. |
$ EXECUTIONCONTEXT | Reprezentuje obiekt EngineIntrinsics, który reprezentuje kontekst wykonywania hosta programu PowerShell. |
$ FALSE | Reprezentuje FALSE. Możesz użyć tej zmiennej do reprezentowania FALSE w poleceniach i skryptach zamiast używać ciągu „false”. |
$ FOREACH | Reprezentuje moduł wyliczający (nie wartości wynikowe) pętli ForEach. Możesz użyć właściwości i metod modułów wyliczających na wartości zmiennej $ ForEach. |
$ HOME | Reprezentuje pełną ścieżkę katalogu domowego użytkownika. |
$ HOST | Reprezentuje obiekt, który reprezentuje bieżącą aplikację hosta dla programu PowerShell. |
$ INPUT | Reprezentuje moduł wyliczający, który wylicza wszystkie dane wejściowe, które są przekazywane do funkcji. |
$ LASTEXITCODE | Reprezentuje kod zakończenia ostatniego uruchomionego programu opartego na systemie Windows. |
$ MECZÓW | Zmienna $ Matches działa z operatorami -match i -notmatch. |
$ MYINVOCATION | $ MyInvocation jest wypełniane tylko dla skryptów, funkcji i bloków skryptów. Właściwości PSScriptRoot i PSCommandPath zmiennej automatycznej $ MyInvocation zawierają informacje o inwokatorze lub skrypcie wywołującym, a nie o bieżącym skrypcie. |
$ NESTEDPROMPTLEVEL | Reprezentuje bieżący poziom monitu. |
$ NULL | $ null to zmienna automatyczna, która zawiera wartość NULL lub pustą. Możesz użyć tej zmiennej do reprezentowania nieobecnej lub niezdefiniowanej wartości w poleceniach i skryptach. |
$ PID | Reprezentuje identyfikator procesu (PID) procesu, który obsługuje bieżącą sesję programu PowerShell. |
$ PROFILE | Reprezentuje pełną ścieżkę profilu programu PowerShell dla bieżącego użytkownika i bieżącej aplikacji hosta. |
$ PSCMDLET | Reprezentuje obiekt, który reprezentuje uruchamiane polecenie cmdlet lub funkcję zaawansowaną. |
$ PSCOMMANDPATH | Reprezentuje pełną ścieżkę i nazwę pliku uruchamianego skryptu. |
$ PSCULTURE | Reprezentuje nazwę kultury aktualnie używanej w systemie operacyjnym. |
$ PSDEBUGCONTEXT | Podczas debugowania ta zmienna zawiera informacje o środowisku debugowania. W przeciwnym razie zawiera wartość NULL. |
$ PSHOME | Reprezentuje pełną ścieżkę katalogu instalacyjnego programu PowerShell. |
$ PSITEM | To samo co $ _. Zawiera bieżący obiekt w obiekcie potoku. |
$ PSSCRIPTROOT | Reprezentuje katalog, z którego jest uruchamiany skrypt. |
$ PSSENDERINFO | Reprezentuje informacje o użytkowniku, który uruchomił PSSession, w tym tożsamość użytkownika i strefę czasową komputera źródłowego. |
$ PSUICULTURE | Reprezentuje nazwę kultury interfejsu użytkownika (UI), która jest obecnie używana w systemie operacyjnym. |
$ PSVERSIONTABLE | Reprezentuje tabelę skrótów tylko do odczytu, która wyświetla szczegółowe informacje o wersji programu PowerShell, która jest uruchomiona w bieżącej sesji. |
$ SENDER | Reprezentuje obiekt, który wygenerował to zdarzenie. |
$ SHELLID | Reprezentuje identyfikator bieżącej powłoki. |
$ STACKTRACE | Reprezentuje ślad stosu dla ostatniego błędu. |
$ THIS | W bloku skryptu, który definiuje właściwość skryptu lub metodę skryptu, zmienna $ This odnosi się do rozszerzanego obiektu. |
$ TRUE | Reprezentuje PRAWDA. Możesz użyć tej zmiennej do reprezentowania wartości TRUE w poleceniach i skryptach. |
PowerShell zapewnia bogaty zestaw operatorów do manipulowania zmiennymi. Możemy podzielić wszystkie operatory PowerShell na następujące grupy -
- Operatory arytmetyczne
- Operatory przypisania
- Operatory porównania
- Operatory logiczne
- Operatory przekierowania
- Rozlane i dołącz do operatorów
- Operatory typu
- Operatory jednoargumentowe
Operatory arytmetyczne
Operatory arytmetyczne są używane w wyrażeniach matematycznych w taki sam sposób, jak w algebrze. W poniższej tabeli wymieniono operatory arytmetyczne -
Załóżmy, że zmienna całkowita A zawiera 10, a zmienna B 20, a następnie -
Pokaż przykłady
Operator | Opis | Przykład |
---|---|---|
+ (Dodawanie) | Dodaje wartości po obu stronach operatora. | A + B da 30 |
- (odejmowanie) | Odejmuje operand po prawej stronie od operandu po lewej stronie. | A - B da -10 |
* (Mnożenie) | Mnoży wartości po obu stronach operatora. | A * B da 200 |
/ (Podział) | Dzieli operand po lewej stronie przez operand po prawej stronie. | B / A da 2 |
% (Moduł) | Dzieli operand po lewej stronie przez operand po prawej stronie i zwraca resztę. | B% A da 0 |
Operatory porównania
Poniżej znajdują się operatory przypisania obsługiwane przez język PowerShell -
Załóżmy, że zmienna całkowita A zawiera 10, a zmienna B 20, a następnie -
Pokaż przykłady
Operator | Opis | Przykład |
---|---|---|
eq (równa się) | Porównuje dwie wartości, aby były równe lub nie. | A -eq B da fałsz |
ne (nie równa się) | Porównuje dwie wartości, aby nie były równe. | A -ne B da prawdę |
gt (większe niż) | Porównuje pierwszą wartość, aby była większa niż druga. | B -gt A da prawdę |
ge (większe lub równe) | Porównuje pierwszą wartość, aby była większa lub równa drugiej. | B -ge A da prawdę |
lt (mniej niż) | Porównuje pierwszą wartość, aby była mniejsza niż druga. | B-lt A da fałsz |
le (mniejsze lub równe) | Porównuje pierwszą wartość, która jest mniejsza lub równa drugiej. | B -le A da fałsz |
Operatory przypisania
Poniżej znajdują się operatory przypisania obsługiwane przez język PowerShell -
Pokaż przykłady
Operator | Opis | Przykład |
---|---|---|
= | Prosty operator przypisania. Przypisuje wartości z operandów po prawej stronie do operandów po lewej stronie. | C = A + B przypisze wartość A + B do C. |
+ = | Dodaj operator przypisania AND. Dodaje prawy operand do lewego operandu i przypisuje wynik do lewego operandu. | C + = A jest równoważne C = C + A |
- = | Operator odejmowania AND przypisania. Odejmuje prawy operand od lewego operandu i przypisuje wynik do lewego operandu. | C - = A jest równoważne C = C - A |
Operatory logiczne
W poniższej tabeli wymieniono operatory logiczne -
Załóżmy, że zmienne logiczne A zawierają prawdę, a zmienna B fałsz, a następnie -
Pokaż przykłady
Operator | Opis | Przykład |
---|---|---|
AND (logiczne i) | Nazywany operatorem logicznym AND. Jeśli oba operandy są niezerowe, warunek staje się prawdziwy. | (A-AND B) jest fałszem |
OR (logiczne lub) | Nazywany operatorem logicznym OR. Jeśli którykolwiek z dwóch operandów jest niezerowy, warunek staje się prawdziwy. | (A -LUB B) jest prawdą |
NIE (nie logiczne) | Nazywany operatorem logicznym NOT. Służy do odwracania stanu logicznego operandu. Jeśli warunek jest spełniony, operator logiczny NOT spowoduje fałsz. | -NOT (A - I B) jest prawdą |
Różni operatorzy
Poniżej przedstawiono różne ważne operatory obsługiwane przez język PowerShell -
Pokaż przykłady
Operator | Opis | Przykład |
---|---|---|
> (Operator przekierowania) | Operator przekierowania. Przypisuje dane wyjściowe do wydrukowania do przekierowanego pliku / urządzenia wyjściowego. | dir> test.log wydrukuje listę katalogów w pliku test.log |
Może zaistnieć sytuacja, w której trzeba będzie kilkakrotnie wykonać blok kodu. Ogólnie instrukcje są wykonywane sekwencyjnie: pierwsza instrukcja funkcji jest wykonywana jako pierwsza, po niej następuje druga i tak dalej.
Języki programowania zapewniają różne struktury kontrolne, które pozwalają na bardziej skomplikowane ścieżki wykonywania.
ZA loop instrukcja pozwala na wielokrotne wykonanie instrukcji lub grupy instrukcji, a następująca po niej jest ogólna forma instrukcji pętli w większości języków programowania -
Język programowania PowerShell udostępnia następujące typy pętli do obsługi wymagań dotyczących pętli. Kliknij poniższe łącza, aby sprawdzić ich szczegóły.
Sr.No. | Pętla i opis |
---|---|
1 | dla pętli
Wykonuje sekwencję instrukcji wiele razy i skraca kod zarządzający zmienną pętli. |
2 | pętla forEach
Ulepszona pętla for. Służy głównie do przechodzenia przez kolekcję elementów, w tym tablice. |
3 | pętla while
Powtarza instrukcję lub grupę instrukcji, gdy dany warunek jest prawdziwy. Testuje warunek przed wykonaniem treści pętli. |
4 | zrobić ... pętla while
Podobnie jak instrukcja while, z tą różnicą, że testuje warunek na końcu treści pętli. |
Struktury decyzyjne mają jeden lub więcej warunków, które mają być ocenione lub przetestowane przez program, wraz z instrukcją lub instrukcjami, które mają być wykonane, jeśli warunek zostanie określony jako prawdziwy, i opcjonalnie inne instrukcje do wykonania, jeśli warunek zostanie określony być fałszywym.
Poniżej przedstawiono ogólną formę typowej struktury podejmowania decyzji występującej w większości języków programowania -
Język skryptowy PowerShell zapewnia następujące typy oświadczeń decyzyjnych. Kliknij poniższe łącza, aby sprawdzić ich szczegóły.
Sr.No. | Oświadczenie i opis |
---|---|
1 | jeśli oświadczenie
Na if statement składa się z wyrażenia logicznego, po którym następuje co najmniej jedna instrukcja. |
2 | if ... else oświadczenie
Na if statement może poprzedzać opcjonalne else statement, który jest wykonywany, gdy wyrażenie logiczne ma wartość false. |
3 | zagnieżdżona instrukcja if
Możesz użyć jednego if lub elseif oświadczenie wewnątrz innego if lub elseif sprawozdania). |
4 | instrukcja przełączania
ZA switch Instrukcja umożliwia testowanie zmiennej pod kątem równości względem listy wartości. |
PowerShell zapewnia strukturę danych, rozszerzenie array, który przechowuje sekwencyjną kolekcję elementów dowolnego typu o stałym rozmiarze. Tablica jest używana do przechowywania zbioru danych, ale często bardziej przydatne jest myślenie o tablicy jako o zbiorze zmiennych lub obiektów.
Zamiast deklarować pojedyncze zmienne, takie jak liczba0, liczba1, ... i liczba99, deklarujesz jedną zmienną tablicową, taką jak liczby, i używasz liczb [0], liczb [1] i ..., liczb [99] do reprezentowania indywidualne zmienne.
W tym samouczku przedstawiono sposób deklarowania zmiennych tablicowych, tworzenia tablic i przetwarzania tablic przy użyciu zmiennych indeksowanych.
Deklarowanie zmiennych tablicowych
Aby użyć tablicy w programie, musisz zadeklarować zmienną odwołującą się do tablicy i możesz określić typ tablicy, do której zmienna może się odwoływać. Oto składnia deklarowania zmiennej tablicowej -
Składnia
$A = 1, 2, 3, 4
or
$A = 1..4
Note- Domyślnym typem obiektów tablicy jest System.Object. Metoda GetType () zwraca typ tablicy. Typ można przekazać.
Przykład
Poniższe fragmenty kodu są przykładami tej składni -
[int32[]]$intA = 1500,2230,3350,4000
$A = 1, 2, 3, 4
$A.getType()
To da następujący wynik -
Wynik
IsPublic IsSerial Name BaseType
-------- -------- ---- --------
True True Object[] System.Array
Dostęp do elementów tablicy uzyskuje się za pośrednictwem index. Indeksy tablicowe są oparte na 0; to znaczy, zaczynają się od 0 doarrayRefVar.length-1.
Przykład
Poniższa instrukcja deklaruje zmienną tablicową myList, tworzy tablicę 10 elementów typu double i przypisuje jej odwołanie do myList -
$myList = 5.6, 4.5, 3.3, 13.2, 4.0, 34.33, 34.0, 45.45, 99.993, 11123
Poniższy rysunek przedstawia tablicę myList. Tutaj myList zawiera dziesięć podwójnych wartości, a indeksy są od 0 do 9.
Przetwarzanie tablic
Podczas przetwarzania elementów tablic często używamy obu for pętla lub foreach pętli, ponieważ wszystkie elementy w tablicy są tego samego typu i znany jest rozmiar tablicy.
Przykład
Oto kompletny przykład pokazujący, jak tworzyć, inicjować i przetwarzać tablice -
$myList = 5.6, 4.5, 3.3, 13.2, 4.0, 34.33, 34.0, 45.45, 99.993, 11123
write-host("Print all the array elements")
$myList
write-host("Get the length of array")
$myList.Length
write-host("Get Second element of array")
$myList[1]
write-host("Get partial array")
$subList = $myList[1..3]
write-host("print subList")
$subList
write-host("using for loop")
for ($i = 0; $i -le ($myList.length - 1); $i += 1) {
$myList[$i]
}
write-host("using forEach Loop")
foreach ($element in $myList) {
$element
}
write-host("using while Loop")
$i = 0
while($i -lt 4) {
$myList[$i];
$i++
}
write-host("Assign values")
$myList[1] = 10
$myList
To da następujący wynik -
Wynik
Print all the array elements
5.6
4.5
3.3
13.2
4
34.33
34
45.45
99.993
11123
Get the length of array
10
Get Second element of array
4.5
Get partial array
print subList
4.5
3.3
13.2
using for loop
5.6
4.5
3.3
13.2
4
34.33
34
45.45
99.993
11123
using forEach Loop
5.6
4.5
3.3
13.2
4
34.33
34
45.45
99.993
11123
using while Loop
5.6
4.5
3.3
13.2
Assign values
5.6
10
3.3
13.2
4
34.33
34
45.45
99.993
11123
Przykłady metod tablicowych
Oto kompletny przykład pokazujący operacje na tablicach przy użyciu jej metod
$myList = @(0..4)
write-host("Print array")
$myList
$myList = @(0..4)
write-host("Assign values")
$myList[1] = 10
$myList
To da następujący wynik -
Wynik
Clear array
Print array
0
1
2
3
4
Assign values
0
10
2
3
4
Hashtable przechowuje pary klucz / wartość w tabeli skrótów. Korzystając z tablicy z haszowaniem, określasz obiekt, który jest używany jako klucz, oraz wartość, którą chcesz połączyć z tym kluczem. Generalnie jako klucze używaliśmy ciągów znaków lub liczb.
W tym samouczku przedstawiono, jak deklarować zmienne z funkcją hashy, tworzyć tabele skrótów i przetwarzać tablice skrótów za pomocą jej metod.
Deklarowanie zmiennych haszujących
Aby użyć tablicy hashy w programie, musisz zadeklarować zmienną odwołującą się do tablicy hashy. Oto składnia deklarowania zmiennej haszującej -
Składnia
$hash = @{ ID = 1; Shape = "Square"; Color = "Blue"}
or
$hash = @{}
Note- Uporządkowane słowniki można tworzyć przy użyciu podobnej składni. Uporządkowane słowniki zachowują kolejność, w jakiej wpisy są dodawane, podczas gdy tabele skrótów nie.
Przykład
Poniższe fragmenty kodu są przykładami tej składni -
$hash = [ordered]@{ ID = 1; Shape = "Square"; Color = "Blue"}
Wydrukuj tablicę haszującą.
$hash
Wynik
Name Value
---- -----
ID 1
Color Blue
Shape Square
Dostęp do wartości hashtable można uzyskać za pośrednictwem pliku keys.
> $hash["ID"]
1
Przetwarzanie Hashtable
Notacja kropkowa może być używana do uzyskiwania dostępu do kluczy lub wartości tabel skrótów.
> $hash.keys
ID
Color
Shape
> $hash.values
1
Blue
Square
Przykład
Oto kompletny przykład pokazujący, jak tworzyć, inicjować i przetwarzać tablicę hashy -
$hash = @{ ID = 1; Shape = "Square"; Color = "Blue"}
write-host("Print all hashtable keys")
$hash.keys
write-host("Print all hashtable values")
$hash.values
write-host("Get ID")
$hash["ID"]
write-host("Get Shape")
$hash.Number
write-host("print Size")
$hash.Count
write-host("Add key-value")
$hash["Updated"] = "Now"
write-host("Add key-value")
$hash.Add("Created","Now")
write-host("print Size")
$hash.Count
write-host("Remove key-value")
$hash.Remove("Updated")
write-host("print Size")
$hash.Count
write-host("sort by key")
$hash.GetEnumerator() | Sort-Object -Property key
To da następujący wynik -
Wynik
Print all hashtable keys
ID
Color
Shape
Print all hashtable values
1
Blue
Square
Get ID
1
Get Shape
print Size
3
Add key-value
Add key-value
print Size
5
Remove key-value
print Size
4
sort by key
Name Value
---- -----
Color Blue
Created Now
ID 1
Shape
Square
Wyrażenie regularne to specjalna sekwencja znaków, która pomaga dopasować lub znaleźć inne ciągi lub zestawy ciągów przy użyciu specjalistycznej składni przechowywanej we wzorcu. Można ich używać do wyszukiwania, edycji lub manipulowania tekstem i danymi.
Oto tabela zawierająca listę wszystkich składni metaznaków wyrażeń regularnych dostępnych w programie PowerShell -
Podwyrażenie | mecze |
---|---|
^ | Dopasowuje początek wiersza. |
$ | Dopasowuje do końca wiersza. |
. | Dopasowuje dowolny pojedynczy znak z wyjątkiem nowej linii. Za pomocąm Opcja pozwala również dopasować nową linię. |
[…] | Dopasowuje dowolny pojedynczy znak w nawiasach. |
[^ ...] | Dopasowuje dowolny pojedynczy znak nie w nawiasach. |
\ZA | Początek całego ciągu. |
\ z | Koniec całego ciągu. |
\ Z | Koniec całego ciągu z wyjątkiem dopuszczalnego końcowego terminatora wiersza. |
re* | Dopasowuje 0 lub więcej wystąpień poprzedniego wyrażenia. |
re + | Dopasowuje 1 lub więcej poprzedniej rzeczy. |
re? | Dopasowuje 0 lub 1 wystąpienie poprzedniego wyrażenia. |
re {n} | Dopasowuje dokładnie n liczbę wystąpień poprzedniego wyrażenia. |
re {n,} | Dopasowuje n lub więcej wystąpień poprzedniego wyrażenia. |
re {n, m} | Pasuje do co najmniej n i co najwyżej m wystąpień poprzedniego wyrażenia. |
a | b | Pasuje do a lub b. |
(re) | Grupuje wyrażenia regularne i zapamiętuje dopasowany tekst. |
(?: re) | Grupuje wyrażenia regularne bez zapamiętywania dopasowanego tekstu. |
(?> re) | Dopasowuje niezależny wzorzec bez cofania. |
\ w | Dopasowuje znaki słowa. |
\ W | Dopasowuje znaki inne niż słowa. |
\ s | Odpowiada spacji. Odpowiednik [\ t \ n \ r \ f]. |
\ S | Dopasowuje niebiałą spację. |
\re | Dopasowuje cyfry. Odpowiednik [0-9]. |
\RE | Pasuje do niecyfry. |
\ZA | Dopasowuje początek ciągu. |
\ Z | Dopasowuje koniec ciągu. Jeśli istnieje nowa linia, pasuje ona tuż przed nową linią. |
\ z | Dopasowuje koniec ciągu. |
\SOL | Odpowiada punktowi, w którym zakończył się ostatni mecz. |
\ n | Odwołanie wsteczne do numeru grupy przechwytywania „n”. |
\b | Dopasowuje granice wyrazów poza nawiasami. Dopasowuje znak Backspace (0x08) wewnątrz nawiasów. |
\B | Dopasowuje granice bez słów. |
\ n, \ t itd. | Dopasowuje znaki nowej linii, powroty karetki, tabulatory itp. |
\ Q | Ucieczka (cudzysłów) wszystkie znaki do \ E. |
\MI | Kończy cytowanie zaczynające się od \ Q. |
Oto pełne przykłady pokazujące, jak używać wyrażenia regularnego w PowerShell;
Sr.No. | Dopasowanie i opis |
---|---|
1 | Dopasuj znaki
Przykład obsługiwanych znaków wyrażenia regularnego. |
2 | Dopasuj klasy postaci
Przykład obsługiwanych klas znaków. |
3 | Dopasuj kwantyfikatory
Przykład obsługiwanych kwantyfikatorów. |
Operator Backtick (`) jest również nazywany operatorem zawijania wyrazów. Pozwala na napisanie polecenia w wielu wierszach. Może być również używany dla nowej linii (`n) lub tabulacji (` t) w zdaniach. Zobacz przykłady poniżej -
Przykład 1
Get-Service * | Sort-Object ServiceType `
| Format-Table Name, ServiceType, Status -AutoSize
Stanie się
Get-Service * | Sort-Object ServiceType | Format-Table Name, ServiceType, Status -AutoSize
Sprawdź dane wyjściowe jako
Name ServiceType Status
---- ----------- ------
MSSQLServerADHelper100 Win32OwnProcess Stopped
ntrtscan Win32OwnProcess Running
...
Przykład 2
Korzystanie z nowej linii i karty.
> Write-host "Title Subtitle"
Title Subtitle
> Write-host "Title `nSubtitle"
Title
Subtitle
> Write-host "Title `tSubtitle"
Title Subtitle
Powershell obsługuje trzy typy nawiasów.
Parenthesis brackets. − ()
Braces brackets. − {}
Square brackets. − []
Nawiasy nawiasów
Ten typ nawiasów jest używany do
przekazać argumenty
załączyć wiele zestawów instrukcji
rozwiązać niejednoznaczność
utwórz tablicę
Przykład
> $array = @("item1", "item2", "item3")
> foreach ($element in $array) { $element }
item1
item2
item3
Nawiasy szelek
Ten typ nawiasów jest używany do
załącz oświadczenia
polecenia blokowe
Przykład
$x = 10
if($x -le 20){
write-host("This is if statement")
}
To da następujący wynik -
Wynik
This is if statement.
Nawiasy kwadratowe
Ten typ nawiasów jest używany do
dostęp do tablicy
dostęp do tabel skrótów
filtruj za pomocą wyrażenia regularnego
Przykład
> $array = @("item1", "item2", "item3")
> for($i = 0; $i -lt $array.length; $i++){ $array[$i] }
item1
item2
item3
>Get-Process [r-s]*
Handles NPM(K) PM(K) WS(K) VM(M) CPU(s) Id ProcessName
------- ------ ----- ----- ----- ------ -- -----------
320 72 27300 33764 227 3.95 4028 SCNotification
2298 77 57792 48712 308 2884 SearchIndexer
...
Alias PowerShell to inna nazwa dla polecenia cmdlet lub dowolnego elementu polecenia.
Tworzenie aliasu
Posługiwać się New-Aliaspolecenia cmdlet, aby utworzyć alias. W poniższym przykładzie utworzyliśmy pomoc dotyczącą aliasów dla polecenia cmdlet Get-Help.
New-Alias -Name help -Value Get-Help
Teraz wywołaj alias.
help Get-WmiObject -Detailed
Zobaczysz następujące dane wyjściowe.
NAME
Get-WmiObject
SYNOPSIS
Gets instances of Windows Management Instrumentation (WMI) classes or information about the available classes.
SYNTAX
Get-WmiObject [
...
Uzyskiwanie aliasu
Posługiwać się get-alias polecenia cmdlet, aby uzyskać wszystkie aliasy obecne w bieżącej sesji programu PowerShell.
Get-Alias
Zobaczysz następujące dane wyjściowe.
CommandType Name Definition
----------- ---- ----------
Alias % ForEach-Object
Alias ? Where-Object
Alias ac Add-Content
Alias asnp Add-PSSnapIn
...
Wydrukować