about_Profiles

Краткое описание

Описывает создание и использование профиля PowerShell.

Подробное описание

Можно создать профиль PowerShell для настройки вашей среды и добавления элементов, относящихся к каждому сеансу PowerShell, который вы запускаете.

Профиль PowerShell — это скрипт, выполняющийся при запуске PowerShell. Профиль можно использовать в качестве скрипта входа для настройки среды. Вы можете добавлять команды, псевдонимы, функции, переменные, оснастки, модули и диски PowerShell. Вы также можете добавить в профиль другие элементы, относящиеся к сеансу, чтобы они были доступны в каждом сеансе, не импортируя или повторно создавая их.

PowerShell поддерживает несколько профилей для пользователей и ведущих программ. Однако он не создает профили для вас. В этом разделе описываются профили, а также описывается создание и обслуживание профилей на компьютере.

В ней объясняется, как использовать параметр NoProfile консоли PowerShell (PowerShell.exe) для запуска PowerShell без профилей. Кроме того, она объясняет влияние политики выполнения PowerShell на профили.

Файлы профилей

PowerShell поддерживает различные файлы профилей. Кроме того, ведущие программы PowerShell могут поддерживать собственные профили для конкретного узла.

Например, консоль PowerShell поддерживает следующие базовые файлы профилей. Профили перечислены в порядке приоритета. Первый профиль имеет наивысший приоритет.

Описание Путь
Все пользователи, все узлы Windows — $PSHOME\Profile.ps1
Linux — /usr/local/microsoft/powershell/7/profile.ps1
macOS — /usr/local/microsoft/powershell/7/profile.ps1
Все пользователи, текущий узел 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
Текущий пользователь, все узлы Windows — $Home\[My ]Documents\PowerShell\Profile.ps1
Linux — ~/.config/powershell/profile.ps1
macOS — ~/.config/powershell/profile.ps1
Текущий пользователь, текущий узел Windows — $Home\[My ]Documents\PowerShell\Microsoft.PowerShell_profile.ps1
Linux — ~/.config/powershell/Microsoft.Powershell_profile.ps1
macOS — ~/.config/powershell/Microsoft.Powershell_profile.ps1

Пути профиля включают следующие переменные:

  • Переменная $PSHOME , в которой хранится каталог установки для PowerShell.
  • Переменная $Home , в которой хранится домашний каталог текущего пользователя.

Кроме того, другие программы, на которых размещается PowerShell, могут поддерживать собственные профили. Например, Visual Studio Code поддерживает следующие профили для конкретного узла.

Описание Путь
Все пользователи, текущий узел $PSHOME\Microsoft.VSCode_profile.ps1
Текущий пользователь, текущий узел $Home\[Мои ]Documents\PowerShell\
Microsoft.VSCode_profile.ps1

В справке PowerShell профиль CurrentUser, Current Host — это профиль, который чаще всего называется "ваш профиль PowerShell".

Примечание

В Windows расположение папки "Документы" можно изменить путем перенаправления папок или OneDrive. Не рекомендуется перенаправлять папку "Документы" в сетевую папку или включать ее в OneDrive. Перенаправление папки может привести к сбою скриптов профиля, и модули не загружались.

Переменная $PROFILE

Автоматическая $PROFILE переменная сохраняет пути к профилям PowerShell, доступным в текущем сеансе.

Чтобы просмотреть путь профиля, отобразите значение переменной $PROFILE . Для представления пути можно также использовать $PROFILE переменную в команде.

Переменная $PROFILE сохраняет путь к профилю "Текущий пользователь, текущий узел". Другие профили сохраняются в свойствах заметки переменной $PROFILE .

Например, $PROFILE переменная содержит следующие значения в консоли Windows PowerShell.

Описание Имя
Текущий пользователь, текущий узел $PROFILE
Текущий пользователь, текущий узел $PROFILE.CurrentUserCurrentHost
Текущий пользователь, все узлы $PROFILE.CurrentUserAllHosts
Все пользователи, текущий узел $PROFILE.AllUsersCurrentHost
Все пользователи, все узлы $PROFILE.AllUsersAllHosts

Так как значения переменной $PROFILE изменяются для каждого пользователя и в каждом ведущем приложении, убедитесь, что значения переменных профиля отображаются в каждом используемом ведущем приложении PowerShell.

Чтобы просмотреть текущие значения переменной $PROFILE , введите:

$PROFILE | Get-Member -Type NoteProperty

Переменную можно использовать $PROFILE во многих командах. Например, следующая команда открывает профиль "Текущий пользователь, текущий узел" в Блокноте:

notepad $PROFILE

Следующая команда определяет, создан ли профиль "Все пользователи, все узлы" на локальном компьютере:

Test-Path -Path $PROFILE.AllUsersAllHosts

Создание профиля

Чтобы создать профиль PowerShell, используйте следующий формат команды:

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

Например, чтобы создать профиль для текущего пользователя в текущем ведущем приложении PowerShell, используйте следующую команду:

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

В этой команде инструкция If запрещает перезапись существующего профиля. Замените значение <заполнителя пути профиля> на путь к файлу профиля, который требуется создать.

Примечание

Чтобы создать профили "Все пользователи" в Windows Vista и более поздних версиях Windows, запустите PowerShell с помощью параметра "Запуск от имени администратора ".

Изменение профиля

В текстовом редакторе можно открыть любой профиль PowerShell, например Блокнот.

Чтобы открыть профиль текущего пользователя в текущем ведущем приложении PowerShell в Блокноте, введите:

notepad $PROFILE

Чтобы открыть другие профили, укажите имя профиля. Например, чтобы открыть профиль для всех пользователей всех ведущих приложений, введите:

notepad $PROFILE.AllUsersAllHosts

Чтобы применить изменения, сохраните файл профиля и перезапустите PowerShell.

Выбор профиля

Если вы используете несколько ведущих приложений, поместите элементы, используемые во всех ведущих приложениях, в $PROFILE.CurrentUserAllHosts свой профиль. Поместите элементы, относящиеся к ведущему приложению, например команду, которая задает цвет фона для ведущего приложения, в профиле, относящемся к узлу приложения.

Если вы являетесь администратором, который настраивает PowerShell для многих пользователей, следуйте приведенным ниже рекомендациям.

  • Сохранение общих элементов в $PROFILE.AllUsersAllHosts профиле
  • Хранение элементов, относящихся к ведущему приложению в $PROFILE.AllUsersCurrentHost профилях, относящихся к ведущему приложению
  • Хранение элементов для определенных пользователей в профилях пользователя

Обязательно проверьте документацию ведущего приложения для любой специальной реализации профилей PowerShell.

Использование профиля

Многие элементы, создаваемые в PowerShell, и большинство выполняемых команд влияют только на текущий сеанс. После завершения сеанса элементы удаляются.

Команды и элементы, относящиеся к сеансу, включают переменные, переменные предпочтения, псевдонимы, функции, команды (за исключением Set-ExecutionPolicy) и модули PowerShell, добавляемые в сеанс.

Чтобы сохранить эти элементы и сделать их доступными во всех будущих сеансах, добавьте их в профиль PowerShell.

Другим распространенным способом использования профилей является сохранение часто используемых функций, псевдонимов и переменных. При сохранении элементов в профиле их можно использовать в любом применимом сеансе, не создавая их повторно.

Запуск профиля

При открытии файла профиля он будет пустым. Однако его можно заполнить переменными, псевдонимами и командами, которые вы часто используете.

Вот несколько предложений, которые показано, как приступить к работе.

Добавление команд, которые упрощают открытие профиля

Это особенно полезно, если используется профиль, отличный от профиля "Текущий пользователь, текущий узел". Например, добавьте следующую команду:

function Pro {notepad $PROFILE.CurrentUserAllHosts}

Добавление функции, в которой перечислены псевдонимы для любого командлета.

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

Настройка консоли

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

Добавление настраиваемого запроса PowerShell

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

Дополнительные сведения о командной строке PowerShell см. в about_Prompts.

Параметр NoProfile

Чтобы запустить PowerShell без профилей, используйте параметр NoProfilePowerShell.exe— программу, запускающую PowerShell.

Для начала откройте программу, которая может запустить PowerShell, например Cmd.exe или PowerShell. Можно также использовать диалоговое окно "Запуск" в Windows.

Тип:

PowerShell -NoProfile

Полный список параметров PowerShell.exe введите:

PowerShell -?

Профили и политика выполнения

Политика выполнения PowerShell определяет, можно ли запускать скрипты и загружать файлы конфигурации, включая профили. Политика ограниченного выполнения — это значение по умолчанию. Он предотвращает выполнение всех скриптов, включая профили. Если вы используете политику "Ограниченный", профиль не запускается и его содержимое не применяется.

Команда Set-ExecutionPolicy задает и изменяет политику выполнения. Это одна из немногих команд, которая применяется во всех сеансах PowerShell, так как значение сохраняется в реестре. Его не нужно задавать при открытии консоли, и вам не нужно хранить Set-ExecutionPolicy команду в своем профиле.

Профили и удаленные сеансы

Профили PowerShell не выполняются автоматически в удаленных сеансах, поэтому команды, добавляемые профили, отсутствуют в удаленном сеансе. Кроме того, автоматическая $PROFILE переменная не заполняется в удаленных сеансах.

Чтобы запустить профиль в сеансе, используйте командлет Invoke-Command .

Например, следующая команда запускает профиль "Текущий пользователь, текущий узел" с локального компьютера в сеансе.$s

Invoke-Command -Session $s -FilePath $PROFILE

Следующая команда запускает профиль "Текущий пользователь, текущий узел" с удаленного компьютера в сеансе.$s $PROFILE Так как переменная не заполнена, команда использует явный путь к профилю. Мы используем оператор dot sourcing, чтобы профиль выполнялся в текущей области на удаленном компьютере, а не в собственной области.

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

После выполнения этой команды доступны команды, добавляемые профилем в сеанс $s.

См. также