Utilisations de Powershell
Utilisations de Powershell
Installation de Powershell Core
Winget est un outil en ligne de commande qui permet de découvrir, d’installer, de mettre à niveau, de supprimer et de configurer des applications sur des ordinateurs clients Windows.
Winget est l’interface cliente du service Gestionnaire de package Windows.
Commande pour recherche la version la plus récente de Powershell :
winget search Microsoft.PowerShell

Installer Powershell en utilisant le paramètre id :
winget install --id Microsoft.Powershell --source winget

L’outil Powershell Corre est alors disponible
Les outils de Powershell
Deux outils sont à disposition (ligne de commandes ou éditeur graphique) accessibles par le menu Windows
Windows Powershell (ligne de commandes):

Windows Powershell ISE (ligne de commandes et éditeur) :

Les touches les plus intéressantes :

Exemple avec la touche F7 :

Une fois la commande retrouvée dans l’historique, vous pouvez soit presser la touche [Entrée] pour la sélectionner et l’exécuter, soit presser la flèche droite (ou gauche) pour modifier la commande avant de l’exécuter.
La touche tabulation [tab] permet de compléter le nom des commandes, le nom des paramètres et les chemins d’accès aux fichiers et dossiers.
L’action successive de la touche tabulation [tab] liste les éléments commençant par les caractères spécifiés.

Obtenir de l’aide sur une commande
Afficher l’aide sur la commande Get-Alias
Afficher l’aide avec les exemples sur la commande Get-Alias
En vous aidant de cette aide : Afficher tous les alias dont le nom commence par la lettre g
Get-Alias -Name g*

Afficher la commande qui correspond à l’alias dont le nom est sl Get-Alias -Name sl*

Afficher tous les alias dont la définition est Get-ChildItem
Get-Alias -Definition Get-ChildItem

A partir de la commande Get-PSDrive, afficher les informations du volume nommé C :
Get-PSDrive C

Afficher les méthodes et les propriétés des objets retournés par la commande Get-Location :
Get-Location | Get-Member

Afficher les méthodes et les propriétés des objets retournés par la commande Get-PSDrive :
Get-PSDrive | Get-Member

Gérer les fichiers et les dossiers
Afficher le chemin du dossier courant
Get-Location

Se déplacer à la racine de la partition C: (chemin c:\)
Set-Location c:\

Afficher la liste des dossiers et fichiers
Get-ChildItem

A cet emplacement, créer un dossier nommé testPowerShell
New-Item c:\testPowerShell -ItemType directory

Se déplacer dans le dossier c:\testPowerShell
Set-Location C:\testPowerShell

Créer un dossier nommé testdossier
New-Item testdossier -ItemType directory

Créer un fichier nommé test1.txt, contenant la phrase "Tp PowerShell 1"
New-Item test1.txt -ItemType file -Value "Tp PowerShell 1"

Afficher la liste des dossiers et fichiers
Get-childItem

Copier le fichier test1.txt sous le nom test2.txt
Copy-Item .\test1.txt -Destination test2.txt
Renommer le fichier test1.txt avec le nom essai1.txt
Rename-Item .\test1.txt -NewName essai1.txt
Copier le fichier essai1.txt dans le dossier testdossier\essai1.txt
Copy-Item .\essai1.txt -Destination .\testdossier\essai1.txt
Afficher la liste des fichiers du dossier et des sous-dossiers de testPowerShell
Get-ChildItem -Recurse

Copier le dossier testdossier (avec ses fichiers) dans un nouveau dossier test2dossier
Copy-Item .\testdossier -Destination test2dossier -Recurse
Déplacer le fichier test2.txt dans le dossier testdossier
Move-Item .\test2.txt -Destination .\testdossier\test2.txt
Supprimer le dossier test2dossier (avec ses fichiers)
Remove-Item .\test2dossier -Recurse
Tester l’existence du dossier c:\windows
Test-Path C:\Windows

Afficher le contenu du dossier c:\windows
Get-ChildItem C:\Windows

Afficher la liste des fichiers .exe du dossier c:\windows
Get-ChildItem C:\Windows\*.exe

ou
Get-ChildItem C:\Windows\* -Include *.exe

Accès aux propriétés et aux méthodes d’un objet
Affecter à la variable $loc, le résultat de la commande Get-Location.
PS C:\testPowerShell> $loc=Get-Location
Afficher les propriétés et les méthodes de la variable $loc
PS C:\testPowerShell> $loc | Get-Member
TypeName: System.Management.Automation.PathInfo
Name MemberType Definition
---------- ----------
….. 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;}
Afficher le chemin du dossier courant contenu dans cette variable.
PS C:\testPowerShell> $loc.Path C:\testPowerShell
Afficher les informations sur le disque contenu par cette variable.
PS C:\testPowerShell> $loc.Drive
Name Used (GB) Free (GB) Provider Root CurrentLocation
--------- --------- -------- ---- ---------------
C 22,11 11,74 FileSystem C:\ testPowerShell
Afficher les informations sur le ‘Provider’ contenu par cette variable.
PS C:\testPowerShell> $loc.Provider
Name Capabilities Drives
------------ ------
FileSystem Filter, ShouldProcess {C, D, F, I}
Affecter à la variable $lect, le résultat de la commande Get-PSDrive –Name C
PS C:\testPowerShell> $lect=Get-PSDrive -Name C
Afficher les propriétés et les méthodes de la variable $lect
PS C:\testPowerShell> $lect | Get-Member
TypeName: System.Management.Automation.PSDriveInfo
Name MemberType Definition
---------- ----------
…… Description Property System.String Description {get;set;} Name Property System.String Name {get;} Provider Property System.Management.Automation.ProviderInfo Provider {get;} Root Property System.String Root {get;} Free ScriptProperty System.Object Free {get=## Ensure that this is a FileSystem drive... Used ScriptProperty System.Object Used {get=## Ensure that this is a FileSystem drive...
A partir de la variable $lect, afficher la description du lecteur C,
PS C:\testPowerShell> $lect.Description production
Afficher la taille en octet du volume utilisé,
PS C:\testPowerShell> $lect.Used 23745740800
PS C:\testPowerShell> $lect.Used/1GB 22,1149444580078
Afficher la taille en octet du volume libre.
PS C:\testPowerShell> $lect.Free 12601737216
PS C:\testPowerShell> $lect.Free/1GB 11,7362823486328
Affecter à la variable $fichier, le résultat de la commande Get-ChildItem c:\testPowerShell\essai1.txt
PS C:\testPowerShell> $fichier=Get-ChildItem C:\testPowerShell\essai1.txt
Afficher les propriétés et les méthodes de la variable $fichier
PS C:\testPowerShell> $fichier | Get-Member
TypeName: System.IO.FileInfo
Name MemberType Definition
---------- ----------
…… CopyTo Method System.IO.FileInfo CopyTo(string destFileName), System.IO.FileInfo ……. Extension Property System.String Extension {get;} FullName Property System.String FullName {get;} …… Name Property System.String Name {get;} ……
A partir de la variable $fichier, afficher le nom du fichier,
PS C:\testPowerShell> $fichier.Name essai1.txt
Afficher la taille en octet du fichier,
PS C:\testPowerShell> $fichier.Length 15
Afficher le nom complet du fichier (avec le chemin),
PS C:\testPowerShell> $fichier.FullName C:\testPowerShell\essai1.txt
Afficher l’extension seule du fichier,
PS C:\testPowerShell> $fichier.Extension .txt
Afficher la date du dernier accès.
PS C:\testPowerShell> $fichier.LastAccessTime
vendredi 2 décembre 2011 15:39:34 A l’aide d’une méthode de la variable $fichier, copier ce fichier dans un nouveau fichier nommé C:\TestPowerShell\essai2.txt
PS C:\testPowerShell> $fichier.CopyTo("C:\testPowerShell\essai2.txt")
Mode LastWriteTime Length Name
------------- ------ ----
-a--- 02/12/2011 15:39 15 essai2.txt
A partir de la variable $fichier, supprimer le fichier essai1.txt
PS C:\testPowerShell> $fichier.Delete()
Vérifier avec la commande Get-ChildItem
PS C:\testPowerShell> Get-ChildItem
Répertoire : C:\testPowerShell
Mode LastWriteTime Length Name
------------- ------ ----
d---- 02/12/2011 15:49 testdossier -a--- 02/12/2011 15:39 15 essai2.txt
Lancer la commande Get-Process et vérifier que le Bloc-notes soit bien dans les processus actifs
PS C:\testPowerShell> Get-Process
Handles NPM(K) PM(K) WS(K) VM(M) CPU(s) Id ProcessName
------ ----- ----- ----- ------ -- -----------
……
65 7 1432 8804 75 0,03 2184 notepad 675 26 101936 105348 573 8,14 2544 powershell
….
Affecter à la variable $proc, le résultat de la commande Get-Process notepad
PS C:\testPowerShell> $proc=Get-Process notepad
Afficher les propriétés et les méthodes de la variable $proc
PS C:\testPowerShell> $proc | Get-Member
TypeName: System.Diagnostics.Process
Name MemberType Definition
---------- ----------
……. Kill Method System.Void Kill() … Description ScriptProperty System.Object Description ….. Path ScriptProperty System.Object Path {get=$this.Mainmodule.FileName;} ……
A partir de la variable $proc, afficher la description du processus,
PS C:\testPowerShell> $proc.Description Bloc-notes
Afficher le chemin d’accès de l’exécutable.
PS C:\testPowerShell> $proc.Path C:\Windows\system32\notepad.exe
A partir de la variable $proc, supprimer (tuer) le processus du Bloc-notes
PS C:\testPowerShell> $proc.Kill()