====== Powershell (quick-n-dirty) ====== * [[powershell:qnd:Documentation]] * [[powershell:qnd:strings]] * [[powershell:qnd:OS/Environment]] * [[powershell:qnd:File Operations]] * [[powershell:qnd:Output]] * [[powershell:qnd:Network]] * [[powershell:qnd:Scripts and Modules]] ====== Core ====== * The back tick/grave accent (''`'') is the line continuation character * On Powershell CLI press ''Shift + Enter'' to go into multi-line editing mode * To string together multiple commands in one line use the '';'' separator * The pound (''#'') is the single line comment character * ''<#'' and ''#>'' are the markers for a block/multi-line comment * Use ''Ctrl+r'' and ''Ctrl+s'' to search backward and forward through history for the typed text * Use ''F8'' and ''Shift+F8'' to search backward and forward through history for the text already on the command line * Get last command error by referencing ''$?'' variable * ''$()'' is the syntax to do //command substitution// * Wrap identifier names in ''{}'' when they contain special characters like spaces and dashes ====== Command Line ====== * [[https://stackoverflow.com/questions/71174012/how-do-you-edit-the-command-line-in-an-external-editor|Editing commands in external editor of choice]] Example of setting VS Code as the editor used for command line editing '@code --new-window --wait %*' > "$HOME\codewait.cmd" $env:VISUAL = "$HOME/codewait" # Custom key binding Set-PSReadLineKeyHandler -Chord Alt+e -Function ViEditVisually ====== Data Types ====== * Use ''$var.GetType()'' to get data type of variable * [[https://docs.microsoft.com/en-us/powershell/scripting/learn/deep-dives/everything-about-hashtable|hashtables]] ==== scalar ==== $foo = "alpha" ==== array ==== $foo = @() $foo = "alpha", "beta" $foo = @( "alpha" "beta" "gamma" ) ==== hash table ==== $hash = @{} $hash = @{ Number = 1; Shape = "Square"; Color = "Blue"} ===== Variables ===== * Use ''${}'' to reference variables that have names that include special characters (e.g. spaces) or are being used to build a string. For building a string this syntax disambiguates the variable name from the rest of the characters in a string. * ''$()'' is also needed in certain scenarios, more to come on this * If a variable name contains spaces it needs to be wrapped in quotes (e.g. ''$obj."First Name"'' or ''{}''. This might happen with imported CSV data, for example. ====== Control Structures ====== ====== Loops/Iteration ====== ==== For Loop ==== $fruit = @('apple','pear','banana','lemon','lime','mango') For ($i = 0; $i -le $fruit.length; $i++) { Write-Host $fruit[$i]; } ==== Foreach Loop ==== foreach ($file in Get-ChildItem) { # do something with $file } Loop over elements of array and reference the element by the automatic variable for the current element. $array | foreach { $_ } * [[https://adamtheautomator.com/powershell-foreach/]] ==== Hash Table ==== * To loop over the items in a hash table one option is to call ''GetEnumerator()'' on the hash table. $t1 = @{firstname = "Michael"; lastname = "Muse"} foreach ($i in $t1.GetEnumerator()) { $i.value } === Alternatively use the keys === $t1 = @{firstname = "Michael"; lastname = "Muse"} foreach ($i in $t1.keys) { $t1[$i] } ====== Select-String ====== Example of selecting a matching line and 7 lines of context before and after the match. netsh http show urlacl | sls -context 7,7 wsman ====== Working With Objects ====== * ''Get-Member'' to list all object members (properties and methods) ====== Select Objects ====== * ''Select-Object'', alias ''select'' Example of getting just the first item of the listed output ls | select -first 1 == Example: Select all disabled user accounts == The ''Where-Object'' or ''where'' cmdlet allows a collection of objects to be filtered by some specified criteria. Get-ADUser -Credential $Credentials -Server pdc -Filter * -SearchBase "dc=contoso,dc=com" | Where-Object {$_.Enabled -eq $false} Select properties from an object using ''Select-Object'' cmdlet. Selecting NIC name and IP address. Get-NetIPAddress | Select-Object InterfaceAlias, IPAddress ===== Expand Property ===== ====== Get Objects - Where-Object ====== Get-ChildItem -Exclude @("web*", "sql*") ls -Exclude web*,sql* Example using ''-notmatch'' operator and regex to match files that don't begin with ''test''. ls | Where-Object {$_.name -notmatch "^test*"} Example of filtering for files that contain spaces. ls | Where-Object {$_.name -match ".*[ ]+.*"} ====== Selecting Properties ====== List the properties/methods of the returned objects. Example: Get-Command | Get-Members Example: $(get-command)[0] | Get-Member TypeName: System.Management.Automation.AliasInfo Name MemberType Definition ---- ---------- ---------- Equals Method bool Equals(System.Object obj) GetHashCode Method int GetHashCode() GetType Method type GetType() ResolveParameter Method System.Management.Automation.ParameterMetadata ResolveParameter(string name) ToString Method string ToString() CommandType Property System.Management.Automation.CommandTypes CommandType {get;} Definition Property string Definition {get;} Description Property string Description {get;set;} Module Property psmoduleinfo Module {get;} ModuleName Property string ModuleName {get;} Name Property string Name {get;} Options Property System.Management.Automation.ScopedItemOptions Options {get;set;} OutputType Property System.Collections.ObjectModel.ReadOnlyCollection[System.Management.Automation.PS... Parameters Property System.Collections.Generic.Dictionary[string,System.Management.Automation.Paramet... ParameterSets Property System.Collections.ObjectModel.ReadOnlyCollection[System.Management.Automation.Co... ReferencedCommand Property System.Management.Automation.CommandInfo ReferencedCommand {get;} RemotingCapability Property System.Management.Automation.RemotingCapability RemotingCapability {get;} ResolvedCommand Property System.Management.Automation.CommandInfo ResolvedCommand {get;} Source Property string Source {get;} Version Property version Version {get;} Visibility Property System.Management.Automation.SessionStateEntryVisibility Visibility {get;set;} DisplayName ScriptProperty System.Object DisplayName {get=if ($this.Name.IndexOf('-') -lt 0)... HelpUri ScriptProperty System.Object HelpUri {get=$oldProgressPreference = $ProgressPreference... ResolvedCommandName ScriptProperty System.Object ResolvedCommandName {get=$this.ResolvedCommand.Name;} ==== Return just property values (no header) ==== (Get-NetIPAddresses).IPAddress Get-NetIPAddresses | foreach {$_.IPAddress} ==== Return properties with a header ==== Get-NetIPAddresses | Select-Object InterfaceAlias, IPAddress ====== Modules ====== ====== Miscellanea ====== ==== Write current date-time to a file ==== get-date | out-file -FilePath c:\test.txt ==== Detect if software is installed ==== $null -eq (wmic product get name | select-string "sentinelone") if ($null -eq (wmic product get name | select-string "sentinelone")) { msiexec.exe /i \\server_name\share_name\sentinel_installer.msi SITE_TOKEN=$site_token /qn /norestart } ==== Redirect command history to Notepad ==== notepad (Get-PSReadLineOption | select -ExpandProperty HistorySavePath) ====== Powershell Meta ====== * Use ''Get-Help'' to show command documentation ==== Find Commands ==== Find commands when you know part of the name. Get-Command | Where-Object {$_.Name -like "*csv*"} Get-Command *csv* Get-Command | Select-String *csv* List commands in module Get-Command -Module Examples of getting path to executables Get-Command notepad CommandType Name Version Source ----------- ---- ------- ------ Application notepad.exe 10.0.19... C:\Windows\system32\notepad.exe where.exe notepad ==== Lookup Alias ==== Get-Alias | Where-=Object {$_.Name -like "*where*"} ==== List Installed Modules ==== Get-Module -ListAvailable ==== Get Module Version ==== === Example === Get-Module -Name Microsoft.Online.SharePoint.PowerShell -ListAvailable | Select Name,Version ==== Get Module Cmdlets ==== === Example === Get-command -Module Microsoft.Online.SharePoint.PowerShell