Powershell - tworzenie skryptów

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;}