Partager via


about_Profiles

Description courte

Décrit comment créer et utiliser un profil PowerShell.

Description longue

Vous pouvez créer un profil PowerShell pour personnaliser votre environnement et ajouter des éléments spécifiques à la session à chaque session PowerShell que vous démarrez.

Un profil PowerShell est un script qui s’exécute au démarrage de PowerShell. Vous pouvez utiliser le profil comme script d’ouverture de session pour personnaliser l’environnement. Vous pouvez ajouter des commandes, des alias, des fonctions, des variables, des composants logiciels enfichables, des modules et des lecteurs PowerShell. Vous pouvez également ajouter d’autres éléments spécifiques à une session à votre profil afin qu’ils soient disponibles dans chaque session sans avoir à les importer ou à les recréer.

PowerShell prend en charge plusieurs profils pour les utilisateurs et les programmes hôtes. Toutefois, il ne crée pas les profils pour vous. Cette rubrique décrit les profils et explique comment créer et gérer des profils sur votre ordinateur.

Il explique comment utiliser le paramètre NoProfile de la console PowerShell (PowerShell.exe) pour démarrer PowerShell sans profils. De plus, il explique l’effet de la stratégie d’exécution PowerShell sur les profils.

Fichiers de profil

PowerShell prend en charge plusieurs fichiers de profil. En outre, les programmes hôtes PowerShell peuvent prendre en charge leurs propres profils spécifiques à l’hôte.

Par exemple, la console PowerShell prend en charge les fichiers de profil de base suivants. Les profils sont répertoriés dans l’ordre de priorité. Le premier profil a la priorité la plus élevée.

Description Path
Tous les utilisateurs, tous les hôtes Windows - $PSHOME\Profile.ps1
Linux - /usr/local/microsoft/powershell/7/profile.ps1
macOS - /usr/local/microsoft/powershell/7/profile.ps1
Tous les utilisateurs, hôte actuel Windows - $PSHOME\Microsoft.PowerShell_profile.ps1
Linux - /usr/local/microsoft/powershell/7/Microsoft.Powershell_profile.ps1
macOS - /usr/local/microsoft/powershell/7/Microsoft.Powershell_profile.ps1
Utilisateur actuel, tous les hôtes Windows - $Home\[Mon ]Documents\PowerShell\Profile.ps1
Linux - ~/.config/powershell/profile.ps1
macOS - ~/.config/powershell/profile.ps1
Utilisateur actuel, hôte actuel Windows - $Home\[Mon ]Documents\PowerShell\Microsoft.PowerShell_profile.ps1
Linux - ~/.config/powershell/Microsoft.Powershell_profile.ps1
macOS - ~/.config/powershell/Microsoft.Powershell_profile.ps1

Les chemins de profil incluent les variables suivantes :

  • Variable $PSHOME , qui stocke le répertoire d’installation de PowerShell
  • Variable $Home , qui stocke le répertoire de base de l’utilisateur actuel

En outre, d’autres programmes qui hébergent PowerShell peuvent prendre en charge leurs propres profils. Par exemple, Visual Studio Code prend en charge les profils spécifiques à l’hôte suivants.

Description Path
Tous les utilisateurs, Hôte actuel $PSHOME\Microsoft.VSCode_profile.ps1
Utilisateur actuel, hôte actuel $Home\[My ]Documents\PowerShell\
Microsoft.VSCode_profile.ps1

Dans l’aide de PowerShell, le profil « CurrentUser, Current Host » est le profil le plus souvent appelé « votre profil PowerShell ».

Notes

Dans Windows, l’emplacement du dossier Documents peut être modifié par redirection de dossiers ou OneDrive. Nous vous déconseillons de rediriger le dossier Documents vers un partage réseau ou de l’inclure dans OneDrive. La redirection du dossier peut entraîner l’échec de vos scripts de profil et le chargement des modules.

Variable $PROFILE

La variable automatique $PROFILE stocke les chemins des profils PowerShell qui sont disponibles dans la session active.

Pour afficher un chemin d’accès de profil, affichez la valeur de la $PROFILE variable. Vous pouvez également utiliser la $PROFILE variable dans une commande pour représenter un chemin d’accès.

La $PROFILE variable stocke le chemin d’accès au profil « Utilisateur actuel, Hôte actuel ». Les autres profils sont enregistrés dans les propriétés de note de la $PROFILE variable.

Par exemple, la $PROFILE variable a les valeurs suivantes dans la console Windows PowerShell.

Description Nom
Utilisateur actuel, Hôte actuel $PROFILE
Utilisateur actuel, Hôte actuel $PROFILE.CurrentUserCurrentHost
Utilisateur actuel, tous les hôtes $PROFILE.CurrentUserAllHosts
Tous les utilisateurs, hôte actuel $PROFILE.AllUsersCurrentHost
Tous les utilisateurs, tous les hôtes $PROFILE.AllUsersAllHosts

Étant donné que les valeurs de la $PROFILE variable changent pour chaque utilisateur et dans chaque application hôte, veillez à afficher les valeurs des variables de profil dans chaque application hôte PowerShell que vous utilisez.

Pour afficher les valeurs actuelles de la $PROFILE variable, tapez :

$PROFILE | Get-Member -Type NoteProperty

Vous pouvez utiliser la $PROFILE variable dans de nombreuses commandes. Par exemple, la commande suivante ouvre le profil « Utilisateur actuel, Hôte actuel » dans le Bloc-notes :

notepad $PROFILE

La commande suivante détermine si un profil « Tous les utilisateurs, tous les hôtes » a été créé sur l’ordinateur local :

Test-Path -Path $PROFILE.AllUsersAllHosts

Comment créer un profil

Pour créer un profil PowerShell, utilisez le format de commande suivant :

if (!(Test-Path -Path <profile-name>)) {
  New-Item -ItemType File -Path <profile-name> -Force
}

Par exemple, pour créer un profil pour l’utilisateur actuel dans l’application hôte PowerShell actuelle, utilisez la commande suivante :

if (!(Test-Path -Path $PROFILE)) {
  New-Item -ItemType File -Path $PROFILE -Force
}

Dans cette commande, l’instruction If vous empêche de remplacer un profil existant. Remplacez la valeur de l’espace <réservé profile-path> par le chemin d’accès au fichier de profil que vous souhaitez créer.

Notes

Pour créer des profils « Tous les utilisateurs » dans Windows Vista et les versions ultérieures de Windows, démarrez PowerShell avec l’option Exécuter en tant qu’administrateur .

Comment modifier un profil

Vous pouvez ouvrir n’importe quel profil PowerShell dans un éditeur de texte, tel que le Bloc-notes.

Pour ouvrir le profil de l’utilisateur actuel dans l’application hôte PowerShell actuelle dans le Bloc-notes, tapez :

notepad $PROFILE

Pour ouvrir d’autres profils, spécifiez le nom du profil. Par exemple, pour ouvrir le profil pour tous les utilisateurs de toutes les applications hôtes, tapez :

notepad $PROFILE.AllUsersAllHosts

Pour appliquer les modifications, enregistrez le fichier de profil, puis redémarrez PowerShell.

Comment choisir un profil

Si vous utilisez plusieurs applications hôtes, placez les éléments que vous utilisez dans toutes les applications hôtes dans votre $PROFILE.CurrentUserAllHosts profil. Placez les éléments spécifiques à une application hôte, comme une commande qui définit la couleur d’arrière-plan d’une application hôte, dans un profil spécifique à cette application hôte.

Si vous êtes un administrateur qui personnalise PowerShell pour de nombreux utilisateurs, suivez ces instructions :

  • Stocker les éléments communs dans le $PROFILE.AllUsersAllHosts profil
  • Stocker les éléments spécifiques à une application hôte dans $PROFILE.AllUsersCurrentHost des profils spécifiques à l’application hôte
  • Stocker des éléments pour des utilisateurs particuliers dans les profils spécifiques à l’utilisateur

Veillez à case activée la documentation de l’application hôte pour toute implémentation spéciale de profils PowerShell.

Comment utiliser un profil

La plupart des éléments que vous créez dans PowerShell et la plupart des commandes que vous exécutez affectent uniquement la session active. Lorsque vous terminez la session, les éléments sont supprimés.

Les commandes et éléments spécifiques à la session incluent des variables, des variables de préférence, des alias, des fonctions, des commandes (à l’exception de Set-ExecutionPolicy) et des modules PowerShell que vous ajoutez à la session.

Pour enregistrer ces éléments et les rendre disponibles dans toutes les sessions futures, ajoutez-les à un profil PowerShell.

Une autre utilisation courante des profils consiste à enregistrer les fonctions, alias et variables fréquemment utilisés. Lorsque vous enregistrez les éléments dans un profil, vous pouvez les utiliser dans n’importe quelle session applicable sans les recréer.

Comment démarrer un profil

Lorsque vous ouvrez le fichier de profil, il est vide. Toutefois, vous pouvez le remplir avec les variables, alias et commandes que vous utilisez fréquemment.

Voici quelques suggestions pour vous aider à démarrer.

Ajouter des commandes qui facilitent l’ouverture de votre profil

Cela est particulièrement utile si vous utilisez un profil autre que le profil « Utilisateur actuel, hôte actuel ». Par exemple, ajoutez la commande suivante :

function Pro {notepad $PROFILE.CurrentUserAllHosts}

Ajouter une fonction qui répertorie les alias de n’importe quelle applet de commande

function Get-CmdletAlias ($cmdletname) {
  Get-Alias |
    Where-Object -FilterScript {$_.Definition -like "$cmdletname"} |
      Format-Table -Property Definition, Name -AutoSize
}

Personnaliser votre console

function Color-Console {
  $Host.ui.rawui.backgroundcolor = "white"
  $Host.ui.rawui.foregroundcolor = "black"
  $hosttime = (Get-ChildItem -Path $PSHOME\PowerShell.exe).CreationTime
  $hostversion="$($Host.Version.Major)`.$($Host.Version.Minor)"
  $Host.UI.RawUI.WindowTitle = "PowerShell $hostversion ($hosttime)"
  Clear-Host
}
Color-Console

Ajouter une invite PowerShell personnalisée

function Prompt
{
$env:COMPUTERNAME + "\" + (Get-Location) + "> "
}

Pour plus d’informations sur l’invite PowerShell, consultez about_Prompts.

Paramètre NoProfile

Pour démarrer PowerShell sans profils, utilisez le paramètre NoProfile de PowerShell.exe, le programme qui démarre PowerShell.

Pour commencer, ouvrez un programme qui peut démarrer PowerShell, comme Cmd.exe ou PowerShell lui-même. Vous pouvez également utiliser la boîte de dialogue Exécuter dans Windows.

Tapez :

PowerShell -NoProfile

Pour obtenir la liste complète des paramètres de PowerShell.exe, tapez :

PowerShell -?

Profils et stratégie d’exécution

La stratégie d’exécution PowerShell détermine, en partie, si vous pouvez exécuter des scripts et charger des fichiers de configuration, y compris les profils. La stratégie d’exécution restreinte est la stratégie par défaut. Il empêche l’exécution de tous les scripts, y compris les profils. Si vous utilisez la stratégie « Restreint », le profil ne s’exécute pas et son contenu n’est pas appliqué.

Une Set-ExecutionPolicy commande définit et modifie votre stratégie d’exécution. Il s’agit de l’une des rares commandes qui s’applique dans toutes les sessions PowerShell, car la valeur est enregistrée dans le Registre. Vous n’avez pas besoin de la définir lorsque vous ouvrez la console et vous n’avez pas besoin de stocker une Set-ExecutionPolicy commande dans votre profil.

Profils et sessions à distance

Les profils PowerShell ne sont pas exécutés automatiquement dans les sessions à distance. Les commandes ajoutées par les profils ne sont donc pas présentes dans la session distante. En outre, la $PROFILE variable automatique n’est pas remplie dans les sessions distantes.

Pour exécuter un profil dans une session, utilisez l’applet de commande Invoke-Command .

Par exemple, la commande suivante exécute le profil « Utilisateur actuel, hôte actuel » à partir de l’ordinateur local dans la session dans $s.

Invoke-Command -Session $s -FilePath $PROFILE

La commande suivante exécute le profil « Utilisateur actuel, hôte actuel » à partir de l’ordinateur distant dans la session dans $s. Étant donné que la $PROFILE variable n’est pas remplie, la commande utilise le chemin explicite du profil. Nous utilisons l’opérateur d’approvisionnement par points afin que le profil s’exécute dans l’étendue actuelle sur l’ordinateur distant et non dans sa propre étendue.

Invoke-Command -Session $s -ScriptBlock {
  . "$HOME\Documents\WindowsPowerShell\Microsoft.PowerShell_profile.ps1"
}

Après avoir exécuté cette commande, les commandes que le profil ajoute à la session sont disponibles dans $s.

Voir aussi