Echiche : Otụtụ ugboro jụrụ ajụjụ banyere PowerShell.
Ị nwere ike iji nke a ndepụta na ụzọ dị iche iche :
- Ka idetuo / mado iwu n’ime a edemede
- Iji hụ ngwa ngwa syntax nke a kpọmkwem iwu
- Gị ka mma oru ihe ọmụma
- Na-achọpụta iwu
- Iji kwadebe a ọrụ N’ajụjụ ọnụ
Emelitere |
July 02, 2015
|
Chepụtara | powershell-guru.com |
Isi Iyi | igbo.powershell-guru.com |
Udi |
75
|
Ajụjụ |
610
|
System
Otú iji chọpụta mbipụta nke PowerShell?
1 2 3 4 5 6 7 8 9 |
# via Powershell $PSVersionTable.PSVersion.Major # via Registry (Get-ItemProperty -Path 'HKLM:\SOFTWARE\Microsoft\PowerShell\1\PowerShellEngine').PowerShellVersion # Versions 1 and 2 (Get-ItemProperty -Path 'HKLM:\SOFTWARE\Microsoft\PowerShell\3\PowerShellEngine').PowerShellVersion # Versions 3 and 4 # via Remote Invoke-Command -ComputerName $computer -ScriptBlock { $PSVersionTable.PSVersion.Major } |
Olee otú na-agba PowerShell ọzọ mbipụta maka azụ ndakọrịta?
powershell.exe -Version 2.0
Olee otú na-achọ a ntakiri PowerShell mbipụta (3.0 na elu) na a akwukwọ na PowerShell?
#Requires -Version 3.0
Olee otú na-achọ nhazi ùgwù n’ihi na a akwukwọ na PowerShell?
1 2 3 4 5 |
# Solution 1 #Requires -RunAsAdministrator # Solution 2 [bool]((whoami.exe /all) -match 'S-1-16-12288') |
Olee otú ịlele oke nke a akwukwọ na PowerShell?
help -Name .\Get-ExchangeEnvironmentReport.ps1 -Full
Esi ọmụma maka ugbu a ọrụ na PowerShell?
[Security.Principal.WindowsIdentity]::GetCurrent()
Otú ike, dezie, na bubatagharịa a profaịlụ PowerShell?
1 2 3 4 5 6 7 8 9 |
# Create New-Item -Type file -Force $profile # Edit notepad.exe $profile # Reload (without restarting Powershell) & $profile .$profile |
Olee otú ime a kwusi nke 5 sekọnd / nkeji na a akwukwọ na PowerShell?
Start-Sleep -Seconds 5
Start-Sleep -Seconds 300 # 5 minutes
Esi ikpeazụ oge buut na PowerShell?
(Get-CimInstance -ClassName win32_operatingsystem).LastBootUpTime
Esi ụdị ome osooso na PowerShell?
1 |
[PSObject].Assembly.GetType('System.Management.Automation.TypeAccelerators')::Get.GetEnumerator() | Select-Object -Property @{Name='Key'; Expression={$_.Key}},@{name='Value'; Expression={$_.Value}} | Sort-Object -Property Key | Format-Table -AutoSize |
Olee otú depụta mmalite omume na PowerShell?
1 |
Get-WmiObject -Class Win32_StartupCommand | Sort-Object -Property Caption | Format-Table -Property Caption, Command, User -AutoSize |
Olee otú iwepụ ihe ngwa na PowerShell?
1 2 |
$application = Get-WmiObject -Query "SELECT * FROM Win32_Product WHERE Name LIKE 'HP Recovery Manager'" $application.Uninstall() |
Olee otú na nseta ihuenyo nke dum desktọọpụ ma ọ bụ nke na-arụsi ọrụ windo na PowerShell?
Take-ScreenShot -Screen -File 'C:\scripts\screenshot.png' -Imagetype JPEG
Repository : Take-ScreenShot
Esi ozi ọnụ maka MSMQ kwụ n’ahịrị na PowerShell?
1 |
Get-WmiObject -Class Win32_PerfRawData_MSMQ_MSMQQueue -ComputerName $computer | Format-Table -Property Name, MessagesInQueue -AutoSize |
Olee ka na-egbu iwu na PowerShell?
1 2 3 4 5 6 7 8 9 10 11 |
# Restricted - No scripts can be run. Windows PowerShell can be used only in interactive mode. Set-ExecutionPolicy -ExecutionPolicy Restricted # AllSigned - Only scripts signed by a trusted publisher can be run. Set-ExecutionPolicy -ExecutionPolicy AllSigned # RemoteSigned - Downloaded scripts must be signed by a trusted publisher before they can be run. Set-ExecutionPolicy -ExecutionPolicy RemoteSigned # Unrestricted - No restrictions - All Windows PowerShell scripts can be run. Set-ExecutionPolicy -ExecutionPolicy Unrestricted |
Otú ike a na bepụ na PowerShell?
1 2 3 4 |
$shell = New-Object -ComObject WScript.Shell $shortcut = $shell.Createshortcut("$HOME\Desktop\Procexp.lnk") $shortcut.TargetPath = 'C:\SysinternalsSuite\procexp.exe' $shortcut.Save() |
Olee otú tụgide ma ọ bụ iwepụ a omume ka mgbochi ọrụ na PowerShell?
1 2 3 4 |
$shell = New-Object -ComObject shell.application $program = $shell.Namespace($env:windir).Parsename('notepad.exe') $program.Invokeverb('TaskbarPin') $program.Invokeverb('TaskbarUnpin') |
Olee otú imeghe a Windows Explorer na PowerShell?
[Diagnostics.Process]::Start('explorer.exe')
Invoke-Item -Path C:\Windows\explorer.exe
Olee otú depụta ngwaọrụ ọkwọ ụgbọala na PowerShell?
Get-WmiObject -Class Win32_PnPSignedDriver
Get-WindowsDriver -Online -All
driverquery.exe
1 2 3 4 5 6 7 8 9 10 11 |
# Empty GUID $guid = [GUID]::Empty # New GUID (lower case by default) $guid = [GUID]::NewGuid() # New GUID (upper case) $guid = ([GUID]::NewGuid()).ToString().ToUpper() # New GUID with a specific value $guid = [GUID]('bc4ad3d3-d704-4bd0-843f-d607fbbc4cd7') |
Esi na ọnọdụ nke nwa oge ndekọ maka ugbu a ọrụ na PowerShell?
[System.IO.Path]::GetTempPath()
Olee otú isonyere a ụzọ na nwa ụzọ n’ime otu ụzọ na PowerShell?
Join-Path -Path C:\ -ChildPath \windows
Olee otú depụta niile cmdlets “Were- *” na PowerShell?
Get-Command -Verb Get
Olee otú depụta pụrụ iche na usoro nchekwa na PowerShell?
1 |
[System.Enum]::GetNames([System.Environment+SpecialFolder]) | ForEach-Object -Process { $_ + " [System.Environment]::GetFolderPath($_)" } |
Olee otú efego ISO / VHD faịlụ na PowerShell?
Mount-DiskImage 'D:\ISO\file.iso' # ISO
Mount-DiskImage 'D:\VHD\file.vhd' # VHD
Olee otú elele NET Okpokoro nsụgharị arụnyere na PowerShell?
1 |
Get-ChildItem -Path 'HKLM:\SOFTWARE\Microsoft\NET Framework Setup\NDP' -Recurse | Get-ItemProperty -Name Version -EA 0 | Where-Object -FilterScript { $_.PSChildName -match '^(?!S)\p{L}' } | Select-Object -Property PSChildName, Version |
Olee otú elele ma ọ bụrụ na NET Okpokoro mbipụta 4.5 arụnyere na PowerShell?
(Get-ItemProperty -Path 'HKLM:\Software\Microsoft\NET Framework Setup\NDP\v4\Full' -EA 0).Version -like '4.5*'
Olee ka na-amalite na-akwụsị a ndekọ (ike a ndekọ nke Windo PowerShell nnọkọ) na PowerShell?
Start-Transcript -Path 'C:\scripts\transcript.txt
Stop-Transcript
Olee otú ịgbanwe ugbu a ndekọ na a kpọmkwem na PowerShell?
Set-Location -Path 'C:\scripts'
Olee ka ikpochapụ ihuenyo na PowerShell?
Clear-Host
cls # Alias
Olee otú ịgbanwe ngosi mkpebi na PowerShell?
Set-DisplayResolution -Width 1280 -Height 1024 -Force # Windows 2012
Olee otú ịtọ “ihuenyo zuru” windo na PowerShell?
mode.com 300
Oole otu akụkụ (obosara na ịdị elu) nke a foto na PowerShell?
1 2 3 4 5 6 7 |
$picture = New-Object -ComObject Wia.ImageFile $picture.LoadFile('C:\screenshot.jpg') [PSCustomObject] @{ Width = $picture.Width Height = $picture.Height } |
Esi na Windo ngwaahịa isi na PowerShell?
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 |
function Get-WindowsKey { ## function to retrieve the Windows Product Key from any PC ## by Jakob Bindslet (jakob@bindslet.dk) param ($targets = '.') $hklm = 2147483650 $regPath = 'Software\Microsoft\Windows NT\CurrentVersion' $regValue = 'DigitalProductId' Foreach ($target in $targets) { $productKey = $null $win32os = $null $wmi = [WMIClass]"\\$target\root\default:stdRegProv" $data = $wmi.GetBinaryValue($hklm,$regPath,$regValue) $binArray = ($data.uValue)[52..66] $charsArray = 'B', 'C', 'D', 'F', 'G', 'H', 'J', 'K', 'M', 'P', 'Q', 'R', 'T', 'V', 'W', 'X', 'Y', '2', '3', '4', '6', '7', '8', '9' ## decrypt base24 encoded binary data For ($i = 24; $i -ge 0; $i--) { $k = 0 For ($j = 14; $j -ge 0; $j--) { $k = $k * 256 -bxor $binArray[$j] $binArray[$j] = [math]::truncate($k / 24) $k = $k % 24 } $productKey = $charsArray[$k] + $productKey If (($i % 5 -eq 0) -and ($i -ne 0)) { $productKey = '-' + $productKey } } $win32os = Get-WmiObject -Class Win32_OperatingSystem -ComputerName $target $obj = New-Object -TypeName Object $obj | Add-Member -MemberType Noteproperty -Name Computer -Value $target $obj | Add-Member -MemberType Noteproperty -Name Caption -Value $win32os.Caption $obj | Add-Member -MemberType Noteproperty -Name CSDVersion -Value $win32os.CSDVersion $obj | Add-Member -MemberType Noteproperty -Name OSArch -Value $win32os.OSArchitecture $obj | Add-Member -MemberType Noteproperty -Name BuildNumber -Value $win32os.BuildNumber $obj | Add-Member -MemberType Noteproperty -Name RegisteredTo -Value $win32os.RegisteredUser $obj | Add-Member -MemberType Noteproperty -Name ProductID -Value $win32os.SerialNumber $obj | Add-Member -MemberType Noteproperty -Name ProductKey -Value $productKey $obj } } |
Perfmon
Esi na nke ugbu a “% Oge isi etiti” (nkezi) ke ikpeazụ 5 sekọnd (ugboro 10) na PowerShell?
(Get-Counter '\Processor(_total)\% Processor Time' -SampleInterval 5 -MaxSamples 10).CounterSamples.CookedValue
Assemblies
Olee otú iji mara mgbakọ na PowerShell?
1 2 3 4 5 6 |
Add-Type -AssemblyName 'System.Windows.Forms' Add-Type -Path 'C:\Windows\Microsoft.Net\assembly\GAC_MSIL\System.Windows.Forms\v4.0_4.0.0.0__b77a5c561934e089\System.Windows.Forms.dll' # Deprecated [System.Reflection.Assembly]::LoadFrom('C:\Windows\Microsoft.Net\assembly\GAC_MSIL\System.Windows.Forms\v4.0_4.0.0.0__b77a5c561934e089\System.Windows.Forms.dll') |
Olee otú elele ugbu a NET mgbakọ kwajuru na PowerShell?
1 2 3 4 5 |
# Check All [System.AppDomain]::CurrentDomain.GetAssemblies() # Check specific one [System.AppDomain]::CurrentDomain.GetAssemblies() | Where-Object -FilterScript { $_.FullName -like '*forms*' } |
Olee otú ịchọta GAC (Uwa Nzukọ Ngwaahịa) ụzọ na PowerShell?
1 |
(New-Object -TypeName Regex -ArgumentList '(?<=file:///)(.*)(?=\/GAC)', 'IgnoreCase').Match(([PSObject].Assembly.Evidence | Where-Object -FilterScript { $_.Value -ne $null }).Value).Value -replace '/', '\' |
Clipboard
Olee otú idetuo n’ihi ka Osisi oge na PowerShell?
1 |
Get-Process | clip.exe |
Esi ọdịnaya nke osisi oge na PowerShell?
Add-Type -AssemblyName PresentationCore
[Windows.Clipboard]::GetText()
Hotfixes
Esi na idozi ọku arụnyere na PowerShell?
Get-HotFix -ComputerName $computer
Esi na idozi ọku arụnyere tupu / mgbe a kpọmkwem ụbọchị na PowerShell?
Get-HotFix | Where-Object -FilterScript { $_.InstalledOn -lt ([DateTime]'01/01/2015') } # Before 01/01/2015
Get-HotFix | Where-Object -FilterScript {$_.InstalledOn -gt ([DateTime]'01/01/2015')} # After 01/01/2015
Olee otú lelee ma ọ bụrụ a idozi ọkuarụnyere na PowerShell?
Get-HotFix -Id KB2965142
Esi na idozi ọku arụnyere na a na n’ime ime obodo na kọmputa na PowerShell?
Get-HotFix -ComputerName $computer
Pagefile
Esi Peejifaịlụ ọmụma na PowerShell?
Get-WmiObject -Class Win32_PageFileusage | Select-Object -Property Name, CurrentUsage, AllocatedBaseSize, PeakUsage, InstallDate
Esi na-atụ aro saiz (MB) maka Peejifaịlụ na PowerShell?
[Math]::Truncate(((Get-WmiObject -Class Win32_ComputerSystem).TotalPhysicalMemory) / 1MB) * 1.5
Otú ike a Peejifaịlụ (4096 MB) na (D 🙂 ụgbọala nke na-PowerShell?
1 2 3 4 5 |
Set-WmiInstance -Class Win32_PageFileSetting -Arguments @{ Name = 'D:\pagefile.sys' InitialSize = 4096 MaximumSize = 4096 } |
Olee otú ihichapụ a Peejifaịlụ na (C 🙂 ụgbọala nke na-PowerShell?
1 2 3 4 5 |
$privileges = Get-WmiObject -Class Win32_computersystem -EnableAllPrivileges $privileges.AutomaticManagedPagefile = $false $privileges.Put() $pagefile = Get-WmiObject -Query "select * from Win32_PageFileSetting where name='c:\\pagefile.sys'" $pagefile.Delete() # Reboot required |
Maintenance
Olee otú ịlele itisa nke a mbanye na PowerShell?
1 |
$drive = Get-WmiObject -Class Win32_Volume -Filter "DriveLetter = 'c:'" $defragReport = $drive.DefragAnalysis() $defragReport.DefragAnalysis |
Olee otú ịlele disk ohere nke draịva na PowerShell?
1 2 3 4 5 6 7 8 9 10 11 12 13 |
Get-WmiObject -Class Win32_logicaldisk | Format-Table -Property @{ Name = 'Drive' Expression = {$_.DeviceID} }, @{ Name = 'Total size (GB)' Expression = {[decimal]('{0:N0}' -f($_.Size/1gb))} }, @{ Name = 'Free space(GB)' Expression = {[decimal]('{0:N0}'-f($_.Freespace/1gb))} }, @{ Name = 'Free (%)' Expression = {'{0,6:P0}' -f(($_.Freespace/1gb) / ($_.size/1gb))} } -AutoSize |
Files
Olee otú imeghe a faịlụ na PowerShell?
Invoke-Item -Path 'C:\scripts\file.txt'
.'C:\scripts\file.txt'
Olee otú ịgụ faịlụ na PowerShell?
Get-Content -Path 'C:\scripts\file.txt'
gc "C:\scripts\file.txt" # Alias
Olee otú dee mmeputa a faịlụ na PowerShell?
'Line1', 'Line2', 'Line3' | Out-File -FilePath 'C:\scripts\file.txt'
'Line1', 'Line2', 'Line3' | Add-Content -Path file.txt
Esi na aha n’uju nke ugbu a akwukwọ faịlụ na PowerShell?
$MyInvocation.MyCommand.Path
Olee otú mpikota onu / zip faịlụ na PowerShell?
Add-Type -AssemblyName 'System.IO.Compression.Filesystem'
[System.IO.Compression.ZipFile]::CreateFromDirectory($folder,$fileZIP)
Olee otú bụghị mpikota onu / bụghị zip faịlụ na PowerShell?
Add-Type -AssemblyName 'System.IO.Compression.Filesystem'
[System.IO.Compression.ZipFile]::ExtractToDirectory($fileZIP, $folder)
Olee otú ịhụ faịlụ na a ZIP ebeidoteihe na PowerShell?
Add-Type -AssemblyName 'System.IO.Compression.Filesystem'
[System.IO.Compression.ZipFile]::OpenRead($fileZIP)
Olee otú gosipụta saiz nke a faịlụ na KB na PowerShell?
(Get-ChildItem -Path .\winsrv.dll).Length /1KB
(Get-ChildItem -Path .\winsrv.dll).Length /1MB
(Get-ChildItem -Path .\winsrv.dll).Length /1GB
Esi achọta faịlụ ibu ma ọ bụ ihe na-erughị 1 GB na PowerShell?
1 2 3 4 5 |
# Larger than 1 GB Get-ChildItem -Path C:\ -Recurse -ErrorVariable $errorsSearch | Where-Object -FilterScript {$_.Length -gt 1GB} # Less than 1 GB Get-ChildItem -Path C:\ -Recurse -ErrorVariable $errorsSearch | Where-Object -FilterScript {$_.Length -lt 1GB} |
Olee otú na-egosipụta aha a faịlụ na-enweghị ndọtị na PowerShell?
[System.IO.Path]::GetFileNameWithoutExtension('C:\Windows\system32\calc.exe') # Return calc
Olee otú gosipụta ndọtị nke a faịlụ na PowerShell?
[System.IO.Path]::GetExtension('C:\scripts\file.txt') # Return .txt
Esi faịlụ mbipụta nke a faịlụ na PowerShell?
1 2 |
(Get-Item -Path C:\Windows\System32\calc.exe).VersionInfo.FileVersion [System.Diagnostics.FileVersionInfo]::GetVersionInfo('C:\Windows\system32\calc.exe').FileVersion |
Esi na hash nke a faịlụ na PowerShell?
(Get-FileHash $file).Hash
Esi na MD5 / SHA1 elelenchikota nke a faịlụ na PowerShell?
Get-FileHash $file -Algorithm MD5
Get-FileHash $file -Algorithm SHA1
Olee otú na-egosipụta zoro ezo faịlụ na PowerShell?
1 2 3 4 5 |
# Display only hidden files Get-ChildItem -Hidden -File # Display all files (including hidden files) Get-ChildItem -Force -File |
Olee otú lelee ma ọ bụrụ na otu faịlụ nwere ndọtị na PowerShell?
1 |
[System.IO.Path]::HasExtension('C:\hiberfil.sys') |
Olee ka a faịlụ dị ka “Gụọ nanị” na PowerShell?
Set-ItemProperty -Path .\file.txt -Name IsReadOnly -Value $true
Olee otú ịgbanwe “IkpeazụDeeOge” Nyenụ urua maka otu faịlụ na PowerShell?
Set-ItemProperty -Path .\file.txt -Name LastWriteTime -Value ((Get-Date).AddDays(-7))
If not working, use Nirsoft tool: BulkFileChanger.
Olee otú ike ọhụrụ faịlụ na PowerShell?
New-Item -ItemType File -Path 'C:\scripts\file.txt' -Value 'FirstLine'
Olee otú nyegharịa a faịlụ na PowerShell?
Rename-Item -Path 'C:\scripts\file.txt' -NewName 'C:\scripts\powershellguru2.txt'
Olee ka nnukwu / ogbe nyegharịa otutu faịlụ na PowerShell?
Get-ChildItem -Path C:\scripts\txt | Rename-Item -NewName { $_.Name -replace ' ', '_' }
Olee otú ihichapụ a faịlụ na PowerShell?
Remove-Item -Path 'C:\scripts\file.txt'
Olee otú gosipụta 10 ọhụrụ e nke a faịlụ na PowerShell?
Get-Content -Path 'C:\scripts\log.txt' -Tail 10
Olee otú ịkpọghee ọtụtụ faịlụ nke a nchekwa na PowerShell?
Get-ChildItem -Path 'C:\scripts\Modules' | Unblock-File
Esi wepụ efu e si a faịlụ na PowerShell?
(Get-Content -Path file.txt) | Where-Object -FilterScript {$_.Trim() -ne '' } | Set-Content -Path file.txt
Olee otú lelee ma ọ bụrụ na otu faịlụ dị na PowerShell?
1 |
Test-Path -Path 'C:\Windows\notepad.exe' # Return True |
Esi na Kacha ọhụrụ / kasị ochie kere faịlụ na a nchekwa na PowerShell?
1 2 |
Get-ChildItem | Sort-Object -Property CreationTime | Select-Object -Last 1 # Newest Get-ChildItem | Sort-Object -Property CreationTime | Select-Object -First 1 # Oldest |
Esi wepụ oyiri e si a faịlụ na PowerShell?
1 2 |
Get-Content -Path .\file.txt | Select-Object -Unique # Display Get-Content -Path .\file.txt | Select-Object -Unique | Set-Content -Path .\testing.txt # Save |
Esi faịlụ kere ọzọ ma ọ bụ ihe na-erughị 1 ọnwa na a nchekwa na PowerShell?
1 2 3 |
$1MonthAgo = (Get-Date).AddMonths(-1) Get-ChildItem | ?{$_.LastWriteTime -lt $1MonthAgo} | Select-Object LastWriteTime,Name,DirectoryName # More Get-ChildItem | ?{$_.LastWriteTime -gt $1MonthAgo} | Select-Object LastWriteTime,Name,DirectoryName # Less |
Esi faịlụ kere ọzọ ma ọ bụ ihe na-erughị 1 afọ na a nchekwa na PowerShell?
1 2 3 |
$1YearAgo = (Get-Date).AddYears(-1) Get-ChildItem | ?{$_.LastWriteTime -lt $1YearAgo} | Select-Object LastWriteTime,Name,DirectoryName # More Get-ChildItem | ?{$_.LastWriteTime -gt $1YearAgo} | Select-Object LastWriteTime,Name,DirectoryName # Less |
Olee otú mbupu uru nke a agbanwe ka a faịlụ na PowerShell?
Set-Content -Path file.txt -Value $variable
Olee otú ịgụ ọnụ ọgụgụ nke faịlụ (* .txt) na a nchekwa na PowerShell?
1 2 3 |
[System.IO.Directory]::GetFiles('C:\scripts', '*.txt').Count (Get-ChildItem -Path 'C:\scripts' -Filter *.txt).Count (Get-ChildItem -Path 'C:\scripts' -Filter *.txt -Recurse).Count # Recursive |
Olee otú ịchọ a eriri n’ime otutu faịlụ na PowerShell?
Select-String -Path 'C:\*.txt' -Pattern 'Test'
Olee otú na-egosipụta mbụ / n’ahịrị ikpeazụ nke a faịlụ na PowerShell?
1 2 3 4 5 6 7 8 9 |
'Line1', 'Line2', 'Line3' | Out-File -FilePath file.txt # First Line Get-Content -Path .\file.txt | Select-Object -First 1 # Returns Line1 (Get-Content -Path .\file.txt)[0] # Returns Line1 # Last Line Get-Content -Path .\file.txt | Select-Object -Last 1 # Returns Line3 (Get-Content -Path .\file.txt)[-1] # Returns Line3 |
Olee otú na-egosipụta a kpọmkwem akara ọnụ ọgụgụ nke a faịlụ na PowerShell?
1 2 3 |
'Line1', 'Line2', 'Line3' | Out-File -FilePath file.txt Get-Content -Path .\file.txt | Select-Object -Index 0 # Returns Line1 Get-Content -Path .\file.txt | Select-Object -Index 2 # Returns Line3 |
Olee otú ịgụ ọnụ ọgụgụ nke e nke a faịlụ na PowerShell?
1 2 |
'Line1', 'Line2', 'Line3' | Out-File -FilePath file.txt (Get-Content -Path .\file.txt | Measure-Object -Line).Lines # Returns 3 |
Olee otú ịgụ ọnụ ọgụgụ nke odide na okwu nke a faịlụ na PowerShell?
1 2 3 4 5 6 7 8 9 10 |
'Test', 'Powershell', 'Test Powershell' | Out-File -FilePath file.txt # Words (Return 4) (Get-Content -Path .\file.txt | Measure-Object -Word).Words # Characters (Return 23) (Get-Content -Path .\file.txt | Measure-Object -Character).Characters # Characters and ignore whitespaces (Return 22) (Get-Content -Path .\file.txt | Measure-Object -Character -IgnoreWhiteSpace).Characters |
Olee otú ibudata a faịlụ na PowerShell?
Invoke-WebRequest -Uri 'http://www.nirsoft.net/utils/searchmyfiles.zip' -OutFile 'C:\tools\searchmyfiles.zip'
Olee otú gosipụta zuru ụzọ nke a faịlụ na PowerShell?
Resolve-Path -Path .\script.ps1 # Return C:\Scripts\script.ps1
Copy
Olee otú idetuo otu faịlụ ka a nchekwa na PowerShell?
Copy-Item -Path 'C:\source\file.txt' -Destination 'C:\destination'
Olee otú idetuo otu faịlụ ka otutu nchekwa na PowerShell?
1 2 |
$destination = 'C:\destination\Folder1', 'C:\destination\Folder2' $destination | Copy-Item -Path 'C:\source\file.txt' -Recurse -Destination {$_} |
Olee otú idetuo otutu faịlụ ka otu nchekwa na PowerShell?
Get-ChildItem -Path 'C:\source' -Filter *.txt | Copy-Item -Destination 'C:\destination'
Active Directory
Domain & Forest
Esi achọta Global katalọgụ sava na-arụsi ọrụ Ndekọ na PowerShell?
[System.DirectoryServices.ActiveDirectory.Forest]::GetCurrentForest().GlobalCatalogs
Esi achọta saịtị na ọrụ Ndekọ na PowerShell?
[System.DirectoryServices.ActiveDirectory.Forest]::GetCurrentForest().Sites
Esi achọta ugbu a na ngalaba njikwa na PowerShell?
(Get-ADDomainController).HostName
Esi achọta niile ngalaba njikwa na a na ngalaba na PowerShell?
1 2 3 4 5 6 7 8 9 10 11 |
# Solution 1 Get-ADDomainController -Filter * | ForEach-Object -Process {$_.Name} # Solution 2 Get-ADGroupMember 'Domain Controllers' | ForEach-Object -Process {$_.Name} # Solution 3 Get-ADComputer -LDAPFilter '(&(objectCategory=computer)(userAccountControl:1.2.840.113556.1.4.803:=8192))' | ForEach-Object -Process {$_.Name} # Solution 4 [System.DirectoryServices.ActiveDirectory.Domain]::GetCurrentDomain() | ForEach-Object -Process {$_.DomainControllers} | ForEach-Object -Process {$_.Name} |
Olee otú ịchọta AD mmeputakwa ọdịda na PowerShell?
Get-ADReplicationFailure dc02.domain.com # Windows 8 and 2012
Olee otú ịchọta okuteili ndụ maka oké ọhịa na-arụ ọrụ Ndekọ na PowerShell?
1 |
(Get-ADObject -Identity "cn=Directory Service,cn=Windows NT,cn=Services,$(([adsi]('LDAP://RootDSE')).configurationNamingContext)" -Properties tombstonelifetime).tombstonelifetime |
Esi nkọwa nke ọhịa / ngalaba na-arụsi ọrụ Ndekọ na PowerShell?
1 2 |
Get-ADDomain domain.com Get-ADForest domain.com |
Esi n’okporo ụzọ ndị “ehichapụ ihe” akpa na-arụsi ọrụ Ndekọ na PowerShell?
(Get-ADDomain).DeletedObjectsContainer
Olee otú aka AD egweri biini atụmatụ Ọrụ Ndekọ na PowerShell?
1 |
Enable-ADOptionalFeature -Identity 'CN=Recycle Bin Feature,CN=Optional Features,CN=Directory Service,CN=Windows NT,CN=Services,CN=Configuration,DC=domain,DC=com' -Scope ForestOrConfigurationSet -Target 'domain.com' |
Olee otú iji weghachi ihe AD Akaụntụ si egweri biini na-arụsi ọrụ Ndekọ na PowerShell?
Get-ADObject -Filter 'samaccountname -eq "powershellguru"' -IncludeDeletedObjects | Restore-ADObject
Olee otú ịchọta FSMO ọrụ na PowerShell?
1 2 3 4 5 6 7 8 9 10 11 12 13 |
# Solution 1 Get-ADForest | Format-List -Property SchemaMaster, DomainNamingMaster Get-ADDomain | Format-List -Property PDCEmulator, RIDMaster, InfrastructureMaster # Solution 2 netdom query fsmo # Solution 3 [System.DirectoryServices.ActiveDirectory.Forest]::GetCurrentForest().SchemaRoleOwner [System.DirectoryServices.ActiveDirectory.Forest]::GetCurrentForest().NamingRoleOwner [System.DirectoryServices.ActiveDirectory.Domain]::GetCurrentDomain().InfrastructureRoleOwner [System.DirectoryServices.ActiveDirectory.Domain]::GetCurrentDomain().PdcRoleOwner [System.DirectoryServices.ActiveDirectory.Domain]::GetCurrentDomain().RidRoleOwner |
Olee otú jikọọ a kpọmkwem ngalaba njikwa na PowerShell?
Get-ADUser -Identity $user -Server 'serverDC01'
Esi na nke ugbu a jikọọ nkesa na PowerShell?
1 2 |
($env:LOGONSERVER).Substring(2) ([System.Environment]::GetEnvironmentVariable('logonserver')).Substring(2) |
Olee otú ime “gpupdate” na kọmputa PowerShell?
Invoke-GPUpdate -Computer $computer -Force -RandomDelayInMinutes 0 # Windows 2012
Groups
Olee otú ike ọhụrụ ìgwè na Ọrụ Ndekọ na PowerShell?
1 |
New-ADGroup -Name 'Powershell Guru' -SamAccountName powershellguru -GroupCategory Security -GroupScope Global -DisplayName 'Powershell Guru' -Path 'OU=MyOU,DC=domain,DC=com' -Description 'My account' |
Esi wepụ otu ìgwè na Ọrụ Ndekọ na PowerShell?
Remove-ADGroup -Identity 'PowershellGuru'
Olee otú ịgbakwunye a onye ọrụ na otu ìgwè na Ọrụ Ndekọ na PowerShell?
Add-ADGroupMember "Powershell Guru" -Members powershellguru
Esi wepụ a onye ọrụ si otu ìgwè na Ọrụ Ndekọ na PowerShell?
Remove-ADGroupMember 'Powershell Guru' -Members powershellguru
Esi achọta efu iche iche (na-enweghị òtù) na Ọrụ Ndekọ na PowerShell?
Get-ADGroup -Filter * -Properties Members | Where-Object -FilterScript {-not $_.Members}
Olee otú ịgụ efu iche iche (na-enweghị òtù) na Ọrụ Ndekọ na PowerShell?
(Get-ADGroup -Filter * -Properties Members | Where-Object -FilterScript {-not $_.Members}).Count
Esi na òtù nke otu ìgwè na-arụsi ọrụ Ndekọ na PowerShell?
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 |
# Solution 1 Get-ADGroupMember 'Powershell Guru' | ForEach-Object -Process {$_.DistinguishedName} Get-ADGroupMember 'Powershell Guru' | ForEach-Object -Process {$_.Samaccountname} # Solution 2 Get-ADGroup 'Powershell Guru' -Properties Members | Select-Object -Property Members -ExpandProperty Members | Sort-Object # Solution 3 function Get-ADGroupMemberFast { [CmdletBinding()] Param ( [Parameter(Mandatory = $true)] [string]$GroupName ) $de = New-Object -TypeName System.DirectoryServices.DirectoryEntry $ds = New-Object -TypeName System.DirectoryServices.DirectorySearcher $ds.SearchRoot = $de $ds.Filter = "(cn=$group)" $null = $ds.PropertiesToLoad.Add('member') $result = $ds.FindOne() if($result) { $account = $result.GetDirectoryEntry() $account.Properties['member'] | ForEach-Object -Process {$_} } } Get-ADGroupMemberFast -GroupName 'Powershell Guru' |
Esi na òtù nke otu ìgwè na imekwa so na-arụ Ndekọ na PowerShell?
1 2 |
Get-ADGroupMember 'Powershell Guru' -Recursive | ForEach-Object -Process {$_.DistinguishedName} Get-ADGroupMember 'Powershell Guru' -Recursive | ForEach-Object -Process {$_.SamAccountName} |
Olee otú ịgụ ọnụ ọgụgụ nke òtù nke otu ìgwè na / enweghị imekwa so na-arụ Ndekọ na PowerShell?
1 2 |
(Get-ADGroupMember 'Powershell Guru' | ForEach-Object -Process {$_.Samaccountname}).Count (Get-ADGroupMember 'Powershell Guru' -Recursive | ForEach-Object -Process {$_.Samaccountname}).Count |
Users
Olee otú iji a wildcard na nyo nke “Bilie-ADOnye ọrụ” na-arụsi ọrụ Ndekọ na PowerShell?
1 2 3 4 5 6 7 8 9 |
# Filter (Get-ADUser -SearchBase 'OU=myOU,DC=domain,DC=com' -Filter {name -like '*vip*'} -Properties Name).Name # LDAPFilter (Get-ADUser -SearchBase 'OU=myOU,DC=domain,DC=com' -LDAPFilter '(name=*vip*)' -Properties Name).Name # With a variable $user = '*vip*' (Get-ADUser -SearchBase 'OU=myOU,DC=domain,DC=com' -Filter {name -like $user} -Properties Name).Name |
Olee otú ịkwaga a onye ọrụ ọzọ ma ọ na-arụsi ọrụ Ndekọ na PowerShell?
Move-ADObject -Identity $dn -TargetPath 'OU=myOU,DC=domain,DC=com'
Esi achọta niile so na-(kpara akwụ) n’ihi na onye ọrụ na PowerShell?
Get-ADGroup -LDAPFilter "(member:1.2.840.113556.1.4.1941:=$($dn))"
Esi ndị òtù (obere aha / medata) n’ihi na onye ọrụ na PowerShell?
(Get-ADUser $user -Properties MemberOf).MemberOf | ForEach-Object -Process {($_ -split ',')[0].Substring(3)} | Sort-Object
1 2 |
Set-ADUser $samAccountName -DisplayName 'DisplayName' -GivenName 'Test' -Surname 'Powershell' -DisplayName 'Test Powershell' Rename-ADObject $dn -NewName 'Test Powershell' #FullName |
Olee otú ịgbanwe Ikowa, Ulọ ọrụ, na nọmba ekwentị maka a onye ọrụ na akaụntụ na-arụsi ọrụ Ndekọ na PowerShell?
Set-ADUser $samAccountName -Description 'IT Consultant' -Office 'Building B' -OfficePhone '12345'
1 2 3 4 5 |
# 31/12/2015 Set-ADAccountExpiration $samAccountName -DateTime '01/01/2016' # Never Clear-ADAccountExpiration $samAccountName |
Olee otú Ị kpọghee ekwt a onye ọrụ na akaụntụ na-arụsi ọrụ Ndekọ na PowerShell?
Unlock-ADAccount $samAccountName
Olee otú aka / gbanyụọ a onye ọrụ na akaụntụ na-arụsi ọrụ Ndekọ na PowerShell?
1 2 |
Disable-ADAccount $samAccountName Enable-ADAccount $samAccountName |
Esi wepụ a onye ọrụ na akaụntụ na-arụsi ọrụ Ndekọ na PowerShell?
Remove-ADUser $samAccountName
Otú iji tọgharịa paswọọdụ n’ihi na otu onye ọrụ na akaụntụ na-arụsi ọrụ Ndekọ na PowerShell?
1 2 3 4 5 6 7 |
# Solution 1 : ask password $password = Read-Host -Prompt 'New Password' -AsSecureString # Solution 2 : specify password $password = ConvertTo-SecureString -String 'Q>9xYMw<3?' -AsPlainText -Force Get-ADUser -Filter "samaccountname -like 'helpdeskagent*'" | Set-ADAccountPassword -NewPassword $newpwd -Reset -PassThru | Set-ADuser -ChangePasswordAtLogon $true |
Otú iji tọgharịa paswọọdụ ruo ọtụtụ ọrụ akaụntụ (nnukwu) na Ọrụ Ndekọ na PowerShell?
1 2 3 4 5 6 7 |
# Solution 1 : ask password $password = Read-Host -Prompt 'New Password' -AsSecureString # Solution 2 : specify password $password = ConvertTo-SecureString -String 'Q>9xYMw<3?' -AsPlainText -Force Get-ADUser -Filter "samaccountname -like 'helpdeskagent*'" | Set-ADAccountPassword -NewPassword $newpwd -Reset -PassThru | Set-ADuser -ChangePasswordAtLogon $true |
Olee otú ya ịchọta onye nwe nke a faịlụ na Ọrụ Ndekọ na PowerShell?
1 2 3 |
$user = New-Object -TypeName System.Security.Principal.NTAccount -ArgumentList (Get-Acl -Path 'userFile.txt').Owner $sid = $user.Translate([System.Security.Principal.SecurityIdentifier]).Value Get-ADUser $sid |
Olee otú ịchọta ma ọ (nzukọ ofu) n’ihi na onye ọrụ na-arụsi ọrụ Ndekọ na PowerShell?
[regex]::match("$((Get-ADUser $user -Properties DistinguishedName).DistinguishedName)",'(?=OU=)(.*\n?)').value
Esi achọta ndị nwere nkwarụ ọrụ akaụntụ na-arụsi ọrụ Ndekọ na PowerShell?
1 2 |
Search-ADAccount -AccountDisabled Get-ADUser -Filter {Enabled -ne $true} |
Esi achọta kubie ume ọrụ akaụntụ na-arụsi ọrụ Ndekọ na PowerShell?
Search-ADAccount -AccountExpired
Esi achọta Kpọchiri Akpọchi ọrụ akaụntụ na-arụsi ọrụ Ndekọ na PowerShell?
Search-ADAccount -LockedOut
Olee otú ịchọta SID nke a onye ọrụ na akaụntụ na-arụsi ọrụ Ndekọ na PowerShell?
(Get-ADUser $user -Properties SID).SID.Value
Olee otú iji tọghata a na aha njirimara na-SID na-arụsi ọrụ Ndekọ na PowerShell?
1 2 |
$user = New-Object -TypeName System.Security.Principal.NTAccount -ArgumentList ('DOMAIN', 'user') $SID = ($user.Translate([System.Security.Principal.SecurityIdentifier])).Value |
Olee otú iji tọghata a SID ka aha njirimara na-arụsi ọrụ Ndekọ na PowerShell?
1 2 |
$SID = New-Object -TypeName System.Security.Principal.SecurityIdentifier -ArgumentList ('SID') $user = ($SID.Translate( [System.Security.Principal.NTAccount])).Value |
Olee otú gbawaa na-akwanyere ùgwù Aha nke a onye ọrụ na akaụntụ na-arụsi ọrụ Ndekọ na PowerShell?
1 2 3 |
$dn = 'CN=Powershell Test,OU=TEST,DC=domain,DC=com' $dn.Split(',')[0] # Returns "CN=Powershell Test" $dn.Split(',')[0].Split('=')[1] # Returns "Powershell Test" |
Olee otú ịchọta ụbọchị nke ihe e kere eke / mgbanwe nke a onye ọrụ na akaụntụ na-arụsi ọrụ Ndekọ na PowerShell?
Get-ADUser -Identity $user -Properties whenChanged, whenCreated | Format-List -Property whenChanged, whenCreated
1 2 3 |
$schema = [DirectoryServices.ActiveDirectory.ActiveDirectorySchema]::GetCurrentSchema() $schema.FindClass('user').mandatoryproperties | Format-Table $schema.FindClass('user').optionalproperties | Format-Table |
Olee otú esi na LDAP ụzọ a onye ọrụ na-arụsi ọrụ Ndekọ na PowerShell?
1 2 3 4 |
$searcher = New-Object -TypeName DirectoryServices.DirectorySearcher -ArgumentList ([ADSI]'') $searcher.Filter = "(&(objectClass=user)(sAMAccountName= $user))" $searcher = $searcher.FindOne() $pathLDAP = $searcher.Path |
Olee otú ịgbanwe cn (mejupụtara Aha) maka a onye ọrụ na-arụsi ọrụ Ndekọ na PowerShell?
Rename-ADObject $((Get-ADUser $user -Properties DistinguishedName).DistinguishedName) -NewName 'Test Powershell'
Olee otú esi nzukọ Ofu (OU) nne na nna nke onye ọrụ na-arụsi ọrụ Ndekọ na PowerShell?
1 2 |
$dn = (Get-ADUser $user -Properties DistinguishedName).DistinguishedName $parent = $dn.Split(',',2)[1] |
Esi na onye nwe a onye ọrụ (onye kere akaụntụ) na Ọrụ Ndekọ na PowerShell?
1 2 |
$dn = (Get-ADUser $user -Properties DistinguishedName).DistinguishedName $owner = (Get-Acl -Path "AD:$dn").Owner |
Olee otú iji tọghata PwdLastSet àgwà n’ihi na onye ọrụ na-arụsi ọrụ Ndekọ na PowerShell?
1 2 3 4 5 |
# Solution 1 [DateTime]::FromFileTime((Get-ADUser $user -Properties pwdLastSet).pwdLastSet) # Solution 2 w32tm /ntte 130787549514737594 |
Computers
Olee otú nwalee ala ọwa n’etiti obodo na kọmputa na ngalaba na PowerShell?
Test-ComputerSecureChannel
Olee otú ịrụzi ala ọwa n’etiti obodo na kọmputa na ngalaba na PowerShell?
Test-ComputerSecureChannel -Repair
Olee otú iji gbanyụọ kọmputa akaụntụ Ọrụ Ndekọ na PowerShell?
Disable-ADAccount $computer
Esi achọta kọmputa na kpọmkwem Sistem na-arụ ọrụ na-arụsi ọrụ Ndekọ na PowerShell?
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 |
Get-ADComputer -Filter 'OperatingSystem -eq "CentOS"' Get-ADComputer -Filter 'OperatingSystem -eq "GNU/Linux"' Get-ADComputer -Filter 'OperatingSystem -eq "Linux"' Get-ADComputer -Filter 'OperatingSystem -eq "Mac OS X"' Get-ADComputer -Filter 'OperatingSystem -eq "OnTap"' Get-ADComputer -Filter 'OperatingSystem -eq "Red Hat Enterprise Linux Server"' Get-ADComputer -Filter 'OperatingSystem -eq "redhat-linux-gnu"' Get-ADComputer -Filter 'OperatingSystem -eq "Samba"' Get-ADComputer -Filter 'OperatingSystem -eq "Ubuntu"' Get-ADComputer -Filter 'OperatingSystem -eq "Windows NT"' Get-ADComputer -Filter 'OperatingSystem -eq "Windows 2000 Professional"' Get-ADComputer -Filter 'OperatingSystem -eq "Windows 2000 Server"' Get-ADComputer -Filter 'OperatingSystem -eq "Windows XP Professional"' Get-ADComputer -Filter 'OperatingSystem -eq "Windows Server 2003"' Get-ADComputer -Filter 'OperatingSystem -eq "Windows Vista™ Business"' Get-ADComputer -Filter 'OperatingSystem -eq "Windows Vista™ Enterprise"' Get-ADComputer -Filter 'OperatingSystem -eq "Windows Vista™ Entreprise"' Get-ADComputer -Filter 'OperatingSystem -eq "Windows 7 Enterprise"' Get-ADComputer -Filter 'OperatingSystem -eq "Windows 7 Professional"' Get-ADComputer -Filter 'OperatingSystem -eq "Windows 7 Ultimate"' Get-ADComputer -Filter 'OperatingSystem -eq "Windows Server 2008 R2 Enterprise"' Get-ADComputer -Filter 'OperatingSystem -eq "Windows Server 2008 R2 Standard"' Get-ADComputer -Filter 'OperatingSystem -eq "Windows Server® 2008 Enterprise"' Get-ADComputer -Filter 'OperatingSystem -eq "Windows 8 Enterprise"' Get-ADComputer -Filter 'OperatingSystem -eq "Windows 8.1 Enterprise"' Get-ADComputer -Filter 'OperatingSystem -eq "Windows Server 2012 R2 Standard"' Get-ADComputer -Filter 'OperatingSystem -eq "Windows Server 2012 Standard"' |
Organizational Unit (OU)
Otú ike otu nzukọ unit (OU) na Ọrụ Ndekọ na PowerShell?
New-ADOrganizationalUnit -Name 'TEST' -Path 'DC=domain,DC=com'
Esi nzukọ Ofu (OU) nkọwa na Ọrụ Ndekọ na PowerShell?
Get-ADOrganizationalUnit 'OU=TEST,DC=domain,DC=com' -Properties *
Olee otú ịgbanwe nkọwa nke otu nzukọ Ofu (OU) na Ọrụ Ndekọ na PowerShell?
Set-ADOrganizationalUnit 'OU=TEST,DC=domain,DC=com' -Description 'My description'
Olee otú aka / gbanyụọ otu nzukọ unit (OU) si mberede nhichapụ na-arụsi ọrụ Ndekọ na PowerShell?
1 2 3 4 5 |
# Protection ON Set-ADOrganizationalUnit 'OU=TEST,DC=domain,DC=com' -ProtectedFromAccidentalDeletion $true # Protection OFF Set-ADOrganizationalUnit 'OU=TEST,DC=domain,DC=com' -ProtectedFromAccidentalDeletion $false |
Olee otú aka mberede nhichapụ nile nzukọ unit (OU) na Ọrụ Ndekọ na PowerShell?
1 |
Get-ADOrganizationalUnit -Filter * -Property ProtectedFromAccidentalDeletion | Where-Object -FilterScript { $_.ProtectedFromAccidentalDeletion -eq $false } | Set-ADOrganizationalUnit -ProtectedFromAccidentalDeletion $true |
1 2 |
Set-ADOrganizationalUnit 'OU=TEST,DC=domain,DC=com' -ProtectedFromAccidentalDeletion $false Remove-ADOrganizationalUnit 'OU=TEST,DC=domain,DC=com' |
1 2 |
$parent = $dn.Split(',',2)[1] $parent = (Get-ADOrganizationalUnit $parent -Properties CanonicalName).CanonicalName |
Olee otú depụta efu nzukọ Units (OUs) na PowerShell?
1 2 3 4 5 |
# Solution 1 Get-ADOrganizationalUnit -Filter * -Property 'msDS-Approx-Immed-Subordinates' | Where-Object -FilterScript {$_.'msDS-Approx-Immed-Subordinates' -eq 0} # Solution 2 ([adsisearcher]'(objectclass=organizationalunit)').FindAll() | Where-Object -FilterScript { (([adsi]$_.Path).PSbase.Children | Measure-Object).Count -eq 0 } |
Esi njikwa nke otu ìgwè na PowerShell?
(Get-ADGroup $dn -Properties Managedby).Managedby
Regex (Regular Expression)
Olee otú wepụ ihe na adreesị IP V4 (80.80.228.8) na Regex na PowerShell?
$example = 'The IP address is 80.80.228.8'
$ip = [regex]::match($example,'\b\d{1,3}\.\d{1,3}\.\d{1,3}\.\d{1,3}\b').value
Olee otú wepụ a Mac adreesị (C0-D9-62-39-61-2D) na iweputa “-” na Regex na PowerShell?
$example = 'The MAC address is C0-D9-62-39-61-2D'
$mac = [regex]::match($example,'([0-9A-F]{2}[-]){5}([0-9A-F]{2})').value
Olee otú wepụ a Mac adreesị (C0: D9: 62: 39: 61: 2D) na iweputa “:” na Regex na PowerShell?
$example = 'The MAC address is C0:D9:62:39:61:2D'
$mac = [regex]::match($example,'((\d|([a-f]|[A-F])){2}:){5}(\d|([a-f]|[A-F])){2}').value
Olee otú wepụ a ụbọchị (10/02/2015) na Regex na PowerShell?
$example = 'The date is 10/02/2015'
$date = [regex]::match($example,'(\d{2}\/\d{2}\/\d{4})').value
Olee otú wepụ a URL (www.powershell-guru.com) na Regex na PowerShell?
$example = 'The URL is www.powershell-guru.com'
$url = [regex]::match($example,'[a-z]+[:.].*?(?=\s)').value
Olee otú wepụ ihe email (user@domain.com) na Regex na PowerShell?
$example = 'The email is user@domain.com'
$email = [regex]::match($example,'(?i)\b[A-Z0-9._%+-]+@[A-Z0-9.-]+\.[A-Z]{2,4}\b').value
Olee otú wepụ “ozizi” site eriri atụ na Regex na PowerShell?
$example = 'www.powershell-guru.com'
[regex]::match($example,'(?<=-)(.*\n?)(?=.com)').value
Olee otú wepụ “guru.com” site eriri atụ na Regex na PowerShell?
$example = 'www.powershell-guru.com'
[regex]::match($example,'(?<=-)(.*\n?)(?<=.)').value
Olee otú wepụ “powershell-guru.com” site eriri atụ na Regex na PowerShell?
$example = 'www.powershell-guru.com'
[regex]::match($example,'(?<=www.)(.*\n?)').value
Olee otú wepụ “123” site eriri atụ na Regex na PowerShell?
$example = 'Powershell123'
[regex]::match($example,'(\d+)').value
Olee otú wepụ “$” (dollar ịrịba ama) si eriri atụ na Regex na PowerShell?
$example = 'Powershell`$123'
[regex]::match($example,'(\$)').value
Olee otú dochie a agwa (* .com) na ọzọ (* .fr) na a eriri na Regex na PowerShell?
$example = 'www.powershell-guru.com'
[regex]::Replace($example, '.com','.fr')
Olee otú gbapụ a eriri na Regex na PowerShell?
[regex]::Escape('\\server\share')
Memory
Olee otú ịmanye a akpọkọta nke na ebe nchekwa site na mkpofu mkpoko na PowerShell?
[System.GC]::Collect()
[System.GC]::WaitForPendingFinalizers()
Esi ebule saiz nke a na kọmputa na PowerShell?
1 2 3 4 5 6 7 8 |
# Solution 1 Get-CimInstance -ClassName 'cim_physicalmemory' | ForEach-Object -Process {$_.Capacity /1GB} # Solution 2 (Get-WmiObject -Class Win32_ComputerSystem).TotalPhysicalMemory /1GB # Solution 3 (systeminfo.exe | Select-String -Pattern 'Total Physical Memory:').ToString().Split(':')[1].Trim() |
Date
Esi na nke ugbu a ụbọchị na PowerShell?
Get-Date
[Datetime]::Now
Olee otú gosipụta oge dị iche iche usoro na PowerShell?
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 |
### DATE ### Get-Date -Format d : 15/04/2015 Get-Date -Format D : 15 April 2015 Get-Date -Format f : 15 April 2015 14:57 Get-Date -Format F : 15 April 2015 14:57:34 Get-Date -Format g : 15/04/2015 14:57 Get-Date -Format G : 15/04/2015 14:57:34 Get-Date -Format yyyyMMdd : 20150415 Get-Date -UFormat '%d%m%Y' : 15042015 Get-Date -UFormat '%m%d%Y' : 04152015 Get-Date -UFormat '%Y%m%d' : 20150415 Get-Date -UFormat '%d%m%Y' : 15-04-2015 Get-Date -UFormat '%m%d%Y' : 04-15-2015 Get-Date -UFormat '%Y%m%d' : 2015-04-15 ### HOUR ### Get-Date -Format t : 15:31 Get-Date -Format T : 15:31:44 Get-Date -Format HH : 15 (Hour) Get-Date -Format mm : 57 (Minute) Get-Date -Format ss : 34 (Seconds) Get-Date -DisplayHint Time : 15:31:44 ### DAY ### Get-Date -Format dddd : Wednesday Get-Date -Format ddd : Wed Get-Date -Format dd : 15 ### MONTH ### Get-Date -Format MMMM : April Get-Date -Format MMM : Apr Get-Date -Format MM : 04 ### YEAR ### Get-Date -Format yyyy : 2015 |
Olee otú iji tọghata a ụbọchị (Ubọchịoge) ka a ụbọchị (eriri) na PowerShell?
$datetimeToString = '{0:dd/MM/yy}' -f (Get-Date 30/01/2015)
$datetimeToString = (Get-Date 31/01/2015).ToShortDateString()
Olee otú iji tọghata a ụbọchị (eriri) ka a ụbọchị (Ubọchịoge) na PowerShell?
$stringToDatetime = [Datetime]::ParseExact('30/01/2015', 'dd/MM/yyyy', $null)
Olee otú gbakọọ dị iche (nọmba nke Ubọchị, awa, minit, ma ọ bụ Sekọnd) n’etiti ụbọchị abụọ na PowerShell?
(New-TimeSpan -Start $dateStart -End $dateEnd).Days
(New-TimeSpan -Start $dateStart -End $dateEnd).Hours
(New-TimeSpan -Start $dateStart -End $dateEnd).Minutes
(New-TimeSpan -Start $dateStart -End $dateEnd).Seconds
Olee otú iji ụbọchị abụọ na PowerShell?
(Get-Date 2015-01-01) -lt (Get-Date 2015-01-30) # True
(Get-Date 2015-01-01) -gt (Get-Date 2015-01-30) # False
Olee otú aka idozi ihe n’usoro nke ụbọchị dị ka “Ubọchịoge” na PowerShell?
$arrayDate | Sort-Object -Property {$_ -as [Datetime]}
Olee ka na-amalite na-akwụsị a elekere nkwụsị na PowerShell?
$chrono = [Diagnostics.Stopwatch]::StartNew()
$chrono.Stop()
$chrono
Esi na nke ugbu a n’ụbọchị izu na PowerShell?
(Get-Date).DayOfWeek #Sunday
Esi ụnyaahụ si ụbọchị na PowerShell?
(Get-Date).AddDays(-1)
Esi ọnụ ọgụgụ nke ụbọchị a ọnwa (na Februari 2015) na PowerShell?
[DateTime]::DaysInMonth(2015, 2)
Olee otú ịmara a itu ukwu afọ na PowerShell?
[DateTime]::IsLeapYear(2015)
Olee otú depụta oge zones na PowerShell?
[System.TimeZoneInfo]::GetSystemTimeZones()
Networking
Olee otú encode (na usoro ASCII ) na itapia a URL na PowerShell?
1 2 3 4 5 6 7 8 9 |
# Encode $url = 'http://www.powershell-guru.com' $encoded = [System.Web.HttpUtility]::UrlEncode($url) # Decode $decoded = [System.Web.HttpUtility]::UrlDecode($encoded) # Encoded : http%3a%2f%2fwww.powershell-guru.com # Decoded : http://www.powershell-guru.com |
Gịnị bụ udinha nke ala netwọk iwu na PowerShell?
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 |
# ipconfig Get-NetIPConfiguration Get-NetIPAddress # ping Test-NetConnection # tracert Test-NetConnection -TraceRoute # route Get-NetRoute # nslookup Resolve-DnsName # Windows 8.1 & Windows 2012 ([System.Net.Dns]::GetHostEntry($IP)).Hostname # IP > PC ([System.Net.Dns]::GetHostAddresses($computer)).IPAddressToString # PC > IP |
Esi adreesị IP na PowerShell?
Get-NetIPAddress # Windows 8.1 & Windows 2012
Get-NetIPConfiguration # Windows 8.1 & Windows 2012
Olee otú iji gbanyụọ adreesị IP V6 (IPv6) na PowerShell?
1 |
New-ItemProperty -Path 'HKLM:\SYSTEM\CurrentControlSet\Services\Tcpip6\Parameters' -Name 'DisabledComponents' -Value '0xFFFFFFFF' -PropertyType"DWORD" # Reboot required |
Olee otú emere ebere ihe na adreesị IP V4 (IPv4) na PowerShell?
if([ipaddress]'10.0.0.1'){'validated'}
Esi achọta mpụga adreesị IP na PowerShell?
1 2 3 4 5 6 7 8 9 10 11 12 13 14 |
# Solution 1 (Invoke-WebRequest -Uri 'myexternalip.com/raw').Content (iwr -Uri 'myexternalip.com/raw').Content # Alias # Solution 2 $webClient = New-Object -TypeName System.Net.WebClient $webClient.DownloadString('http://myexternalip.com/raw') # Solution 3 while ($true) { Write-Output -InputObject "$(Get-Date) - $((Invoke-WebRequest -Uri 'http://myexternalip.com/raw' -Method Get).Content)" Start-Sleep -Seconds 300 } |
Olee otú ịchọta Hostname site na adreesị IP na PowerShell?
([System.Net.Dns]::GetHostEntry($IP)).Hostname
Olee otú ịchọta adreesị IP a Usuaha na PowerShell?
([System.Net.Dns]::GetHostAddresses($computer)).IPAddressToString
Olee otú ịchọta FQDN si a Usuaha na PowerShell?
[System.Net.Dns]::GetHostByName($computer).HostName
Esi achọta netwọk nhazi (IP, Subnet, ọnụ ụzọ ámá, na DNS) na PowerShell?
1 |
Get-WmiObject -Class Win32_NetworkAdapterConfiguration | Format-Table -Property Description, IpAddress, IPSubnet, DefaultIPGateway, DNSServerSearchOrder |
Olee otú ịchọta Mac adreesị PowerShell?
Get-CimInstance win32_networkadapterconfiguration | Select-Object -Property Description, Macaddress
Get-WmiObject -Class win32_networkadapterconfiguration | Select-Object -Property Description, Macaddress
Olee otú uda a na kọmputa na PowerShell?
1 2 3 4 5 6 |
# Solution 1 Test-Connection -ComputerName $computer -Quiet # Returns True / False # Solution 2 $ping = New-Object -TypeName System.Net.Networkinformation.Ping $ping.Send($computer) |
Olee otú lelee ma ọ bụrụ na kọmputa na jikọọ na internet na PowerShell?
1 |
[Activator]::CreateInstance([Type]::GetTypeFromCLSID([Guid]'{DCB00C01-570F-4A9B-8D69-199FDBA5723B}')).IsConnectedToInternet |
Olee otú ịrụ a “whois” Nchọgharị maka a website na PowerShell?
$whois = New-WebServiceProxy 'http://www.webservicex.net/whois.asmx?WSDL'
$whois.GetWhoIs('powershell-guru.com')
Esi nkọwa nke a n’ihu ọha IP (Geolocation) na PowerShell?
1 2 |
$externalIP = (Invoke-WebRequest -Uri 'myexternalip.com/raw').Content $detailsIP = ([xml](Invoke-WebRequest -Uri "http://freegeoip.net/xml/$externalIP" -UseBasicParsing).Content).Response |
Olee otú lelee ma ọ bụrụ a mmiri n’ọdụ ụgbọ mmiri bụ na-emeghe / emechi na PowerShell?
New-Object -TypeName Net.Sockets.TcpClient -ArgumentList $computer, 135
Olee otú ime “tracert” na PowerShell?
Test-NetConnection www.google.com -TraceRoute
Olee otú idozi a n’ụlọ netwọk njikọ profaịlụ PowerShell?
Get-NetAdapter | Format-Table -Property Name, InterfaceDescription, ifIndex -AutoSize # Windows 8.1
Set-NetConnectionProfile -InterfaceIndex 6 -NetworkCategory Private
Olee otú na-egosi TCP mmiri n’ọdụ ụgbọ mmiri njikọ PowerShell?
netstat.exe -ano
Get-NetTCPConnection #Windows 8 and 2012
Olee ka ebelata a ogologo URL n’ime a obere URL na PowerShell?
$url = 'www.powershell-guru.com'
$tiny = Invoke-RestMethod -Uri "http://tinyurl.com/api-create.php?url=$url"
Esi proxy ntọala na PowerShell?
Get-ItemProperty -Path HKCU:"Software\Microsoft\Windows\CurrentVersion\Internet Settings"
DNS
Olee otú ịlele DNS cache na mpaghara na kọmputa na PowerShell?
ipconfig.exe /displaydns
Get-DnsClientCache #Windows 8 and 2012
Olee otú ikpochapụ a DNS cache na mpaghara na kọmputa na PowerShell?
ipconfig.exe /flushdns
Start-Process -FilePath ipconfig -ArgumentList /flushdns -WindowStyle Hidden
Clear-DnsClientCache #Windows 8 and 2012
Olee otú ikpochapụ a DNS cache na n’ime obodo kọmputa na PowerShell?
Invoke-Command -ScriptBlock {Clear-DnsClientCache} -ComputerName computer01, computer02
Olee otú ịgụ ụsụụ ndị agha faịlụ na PowerShell?
Get-Content -Path 'C:\Windows\system32\drivers\etc\hosts'
Password
Olee otú n’ịwa a nkịtị paswọọdụ na PowerShell?
[Reflection.Assembly]::LoadWithPartialName('System.Web')
[System.Web.Security.Membership]::GeneratePassword(30,2)
Olee otú ịgbanwe obodo paswọọdụ maka onye nchịkwa a ime ihe nkesa na PowerShell?
$admin = [ADSI]('WinNT://server01/administrator,user')
$admin.SetPassword($password)
$admin.SetInfo()
Esi achọta paswọọdụ ngafe ụbọchị nke otu akaụntụ Ọrụ Ndekọ na PowerShell?
1 2 3 4 5 6 7 8 |
# Solution 1 [DateTime]::FromFileTime((Get-ADUser -Identity $user -Properties 'msDS-UserPasswordExpiryTimeComputed').'msDS-UserPasswordExpiryTimeComputed') # Solution 2 Get-Date -Date ((Get-ADUser $user -Properties 'msDS-UserPasswordExpiryTimeComputed' | Select-Object -Property @{ Name = 'ExpiryDate' Expression = {[DateTime]::FromFileTime($_.'msDS-UserPasswordExpiryTimeComputed')} }).ExpiryDate)-Format 'F' |
Printers
Olee otú depụta niile na-ebi akwụkwọ nke a kpọmkwem nkesa na PowerShell?
Get-WmiObject -Query 'Select * From Win32_Printer' -ComputerName $computer
Olee otú depụta niile ọdụ ụgbọ mmiri nke a kpọmkwem nkesa na PowerShell?
Get-WmiObject -Class Win32_TCPIPPrinterPort -Namespace 'root\CIMV2' -ComputerName $computer
Olee otú ịgbanwe ikwu / ọnọdụ nke a na ngwa nbipute na PowerShell?
1 2 3 4 |
$printer = Get-WmiObject -Class win32_printer -Filter "Name='HP Deskjet 2540 series'" $printer.Location = 'Germany' $printer.Comment = 'Printer - Test' $printer.Put() |
Olee otú kpochapu (ịkagbu niile ọrụ) a na ngwa nbipute na PowerShell?
$printer = Get-WmiObject -Class win32_printer -Filter "Name='HP Deskjet 2540 series'"
$printer.CancelAllJobs()
Olee otú ibipụta a ule na peeji nke a na ngwa nbipute na PowerShell?
$printer = Get-WmiObject -Class win32_printer -Filter "Name='HP Deskjet 2540 series'"
$printer.PrintTestPage()
Esi na-ebipụta queues n’ihi na-ebi akwụkwọ na PowerShell?
1 2 3 4 |
Get-WmiObject -Class Win32_PerfFormattedData_Spooler_PrintQueue | Select-Object -Property Name, @{ Expression = {$_.jobs} Label = 'Current Jobs' } | Format-Table -AutoSize |
Regedit
Read
Olee otú depụta ndekọ ekwo na PowerShell?
Get-ChildItem -Path Registry::
Esi ndekọ ụkpụrụ na uru ụdị na PowerShell?
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 |
function Get-RegistryValue { Param ( [Parameter(Mandatory = $true)] [string]$RegistryKey ) $key = Get-Item -Path "Registry::$RegistryKey" $key.GetValueNames() | Sort-Object | ForEach-Object -Process { $name = $_ $type = $key.GetValueKind($name) switch ($type) { 'String' {'REG_SZ'} 'Binary' {'REG_BINARY'} 'Dword' {'REG_DWORD'} 'Qword' {'REG_QWORD'} 'MultiString' {'REG_MULTI_SZ'} 'ExpandString'{'REG_EXPAND_SZ'} Default {$null} } [PSCustomObject]@{ Name = $name Type = $type Data = $key.GetValue($name) } } } |
Olee otú depụta ndekọ isi subkeys na PowerShell?
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 |
#HKEY_CLASSES_ROOT New-PSDrive -PSProvider Registry -Root HKEY_CLASSES_ROOT -Name HKCR Get-ChildItem -Path 'HKCR:\' #HKEY_CURRENT_USER Get-ChildItem -Path 'HKCU:\Software' Get-ChildItem -Path Registry::HKEY_CURRENT_USER #HKEY_LOCAL_MACHINE Get-ChildItem -Path 'HKLM:\SYSTEM' Get-ChildItem -Path Registry::HKEY_LOCAL_MACHINE #HKEY_USERS New-PSDrive -PSProvider Registry -Root HKEY_USERS -Name HKU Get-ChildItem -Path 'HKU:\' #HKEY_CURRENT_CONFIG New-PSDrive -PSProvider Registry -Root HKEY_CURRENT_CONFIG -Name HKCC Get-ChildItem -Path 'HKCC:\' |
Olee otú depụta ndekọ isi obere isi na a imekwa ụzọ na PowerShell?
Get-ChildItem -Path 'HKLM:\SYSTEM' -Recurse -ErrorAction SilentlyContinue
Esi achọta obere isi na kpọmkwem aha na PowerShell?
Get-ChildItem -Path 'HKLM:\SOFTWARE' -Include *Plugin* -Recurse -ErrorAction SilentlyContinue
Olee otú laghachi naanị aha ndekọ obere isi na PowerShell?
(Get-ChildItem -Path 'HKLM:\SYSTEM').Name # Return HKEY_LOCAL_MACHINE\SYSTEM\ControlSet
Get-ChildItem -Path 'HKLM:\SYSTEM' -Name # Return ControlSet
Olee otú depụta ndekọ ụkpụrụ na PowerShell?
Get-ItemProperty -Path 'HKLM:\SOFTWARE\Microsoft\Windows NT\CurrentVersion'
Olee otú ịgụ a kpọmkwem ndekọ uru na PowerShell?
(Get-ItemProperty -Path 'HKLM:\SOFTWARE\Microsoft\Windows NT\CurrentVersion').ProductName
Olee otú ịgụ a kpọmkwem ndekọ uru na a na n’ime ime obodo na kọmputa na PowerShell?
1 2 3 4 5 |
$hostname = $computer $openRegedit = [Microsoft.Win32.RegistryKey]::OpenRemoteBaseKey('LocalMachine', $hostname) $openKey = $openRegedit.OpenSubKey('SOFTWARE\\Microsoft\\Windows NT\\CurrentVersion') $keyValue = $openKey.GetValue('ProductName') $keyValue |
Write
Olee otú ike ọhụrụ ndekọ isi na PowerShell?
New-Item -Path 'HKCU:\Software\MyApplication'
Otú ike a ndekọ uru na PowerShell?
New-ItemProperty -Path 'HKCU:\Software\MyApplication' -Name 'Version' -Value '1.0'
Olee otú gbanwee dịbunụ ndekọ uru na PowerShell?
Set-ItemProperty -Path 'HKCU:\Software\MyApplication' -Name 'Version' -Value '2.0'
Delete
Olee otú ihichapụ a ndekọ uru na PowerShell?
Remove-ItemProperty -Path 'HKCU:\Software\MyApplication' -Name 'Version'
Olee otú ihichapụ a ndekọ isi na PowerShell?
Remove-Item -Path 'HKCU:\Software\MyApplication' -Force
Test
Olee otú nwalee ma ọ bụrụ na a ndekọ isi dị na PowerShell?
Test-Path -Path 'HKCU:\Software\MyApplication'
Olee otú nwalee ma ọ bụrụ na a ndekọ uru dị na PowerShell?
(Get-Item -Path 'HKCU:\Software\MyApplication').GetValueNames() -contains 'Version'
Strings
Esi wepụ ọcha-ohere odide site na mmalite nke a eriri na PowerShell?
$string = ' PowershellGuru'
$string = $string.TrimStart()
Esi wepụ ọcha-ohere odide si ọgwụgwụ nke a eriri na PowerShell?
$string = 'PowershellGuru '
$string = $string.TrimEnd()
Esi wepụ ọcha-ohere odide (amalite na-agwụcha) nke a eriri na PowerShell?
$string = ' PowershellGuru '
$string = $string.Trim()
Olee otú iji tọghata a eriri na-elu bụrụ na PowerShell?
$string = 'powershellguru'
$string = $string.ToUpper()
Olee otú iji tọghata a eriri ibuda ala bụrụ na PowerShell?
$string = 'POWERSHELLGURU'
$string = $string.ToLower()
Olee otú iji họrọ obere-eriri “PowerShell” nke eriri “PowerShellOkachamara” na PowerShell?
$string.Substring(0,10)
Olee otú iji họrọ obere-eriri “ozizi” nke eriri “PowerShellOkachamara” na PowerShell?
$string.Substring(10)
Olee ka họrọ nọmba “123” nke “PowerShell123Okachamara” na PowerShell?
$string = 'Powershell123Guru'
[regex]::match($string,'(\d+)').value
Esi efu dabeere ndeksi nke “ozizi” nke eriri “PowerShellOkachamara” na PowerShell?
$string.IndexOf('Guru') # 10
Olee otú lelee ma ọ bụrụ a eriri bụ null ma ọ bụ ihe efu na PowerShell?
$string = $null
$string = ''
[string]::IsNullOrEmpty($string)
Olee otú lelee ma ọ bụrụ a eriri bụ null, efu, ma ọ bụ ndị mejupụtara nanị nke na-acha ọcha-ohere odide na PowerShell?
$string = $null
$string = ''
$string = ' '
[string]::IsNullOrWhiteSpace($string)
Olee otú lelee ma ọ bụrụ a eriri e dere a kpọmkwem akwụkwọ ozi na PowerShell?
$string = 'PowershellGuru'
$string.Contains('s')
[regex]::match($string,'s').Success
Olee otú laghachi ogologo nke a eriri na PowerShell?
$string.Length
Olee otú concatenate abụọ urụk na PowerShell?
1 2 3 4 5 6 7 |
# Solution 1 $string1 + $string2 # Solution 2 $string1 = 'Powershell' $string2 = 'Guru' [string]::Concat($string1,$string2) |
Olee otú iji kwekọọ n’ihi na otu onye ma ọ bụ ọtụtụ mgbodo “[]” na a eriri na PowerShell?
$string = '[PowershellGuru]'
$string -match '\[' # Only 1
$string -match '\[(.*)\]' # Several
Olee otú iji kwekọọ n’ihi na otu onye ma ọ bụ ọtụtụ mgbodo “()” na a eriri na PowerShell?
$string = '(PowershellGuru)'
$string -match '\(' # Only 1
$string -match '\((.*)\)' # Several
Olee otú iji kwekọọ n’ihi na otu onye ma ọ bụ ọtụtụ mgbakọ mgbodo “{}” na a eriri na PowerShell?
$string = '{PowershellGuru}'
$string -match '\{' # Only 1
$string -match '\{(.*)\}' # Several
Olee otú iji kwekọọ n’ihi na otu onye ma ọ bụ ọtụtụ n’akuku mgbodo “<>” na a eriri na PowerShell?
$string = ''
$string -match '\<' # Only 1
$string -match "\<(.*)\>" # Several
Olee otú iji kwekọọ ọ bụla ibuda ala akwụkwọ ozi (ABC) na a eriri na PowerShell?
$string = 'POWERSHELLGURU'
$string -cmatch "^[a-z]*$" #False
Olee otú iji kwekọọ ọ bụla elu elu akwụkwọ ozi (ABC) na a eriri na PowerShell?
$string = 'powershellguru'
$string -cmatch "^[A-Z]*$" #False
Olee otú iji kwekọọ “[p” (p ala ikpe) na a eriri na PowerShell?
$string = '[powershellGuru]'
$string -cmatch '\[[a-z]\w+' #True
Olee otú iji kwekọọ “[P” (P elu ikpe) na a eriri na PowerShell?
$string = '[PowershellGuru]'
$string -cmatch '\[[A-Z]\w+' #True
Olee otú dochie a na akara na ọzọ na akara na PowerShell?
$a = 'Line A'
$b = 'Line B'
$a = $a -replace $a, $b
Olee otú iji tọghata a nkewa ime ka a eriri (pasent) na PowerShell?
(1/2).ToString('P')
Olee otú idozi urụk nwere nọmba na PowerShell?
1 |
'string-10', 'string-2', 'string-23', 'string-30' | Sort-Object -Property {$_ -replace '[\d]'}, {$_ -replace '[a-zA-Z\p{P}]'-as [int]} |
Olee otú iji họrọ ikpeazụ okwu nke a ikpe na PowerShell?
$sentence = 'My name is Test Powershell'
$sentence.Split(' ')[-1] # Returns Powershell
Esi ndị kasị ibu okwu a ikpe na PowerShell?
$sentence = 'My name is Test Powershell'
$sentence.Split(' ') | Sort-Object -Property Length | Select-Object -Last 1 # Returns Powershell
Olee otú ịgụ ọnụ ọgụgụ nke ugboro a eriri bụ ugbu n’ime a ikpe na PowerShell?
$sentence = 'test test test Powershell'
[regex]::Matches($sentence, 'test').Count # Returns 3
Olee otú idetuo ọ bụla agwa na a eriri ka a agwa n’usoro na PowerShell?
1 2 3 4 5 6 7 |
$name = 'test' $name.ToCharArray() s t e v e |
Olee otú iji tọghata akpa leta elu elu ikpe nke a eriri na PowerShell?
1 2 |
$name = 'test' $name.Substring(0,1).ToUpper() + $name.Substring(1) |
Olee ka na mpe mpe akwa (ekpe ma ọ bụ aka nri) a eriri na PowerShell?
1 2 3 4 5 6 7 |
# With whitespaces $padRight = 'test'.PadRight(25) $padLeft = 'test'.PadLeft(25) # With characters $padRight = 'test'.PadRight(25,'.') # Return test.................... $padLeft = 'test'.PadLeft(25,'.') # Return ....................test |
Olee otú encode na itapia a eriri ka Base64 na PowerShell?
1 2 3 4 5 6 7 8 9 10 |
# Encode $string = [System.Text.Encoding]::UTF8.GetBytes('test') $encoded = [System.Convert]::ToBase64String($string) # Decode $string = [System.Convert]::FromBase64String($encoded) $decoded = [System.Text.Encoding]::UTF8.GetString($string) # Encoded : c3RldmU= # Decoded : test |
Olee otú iji tọghata a ọnụ ọgụgụ (ka na site) ọnụọgụ abụọ na PowerShell?
1 2 3 4 5 |
# Base 10 to Base 2 [System.Convert]::ToString(255,2) # Base 2 to Base 10 [System.Convert]::ToInt32('11111111',2) |
Olee otú laghachi naanị ikpeazụ nne na nna nchekwa na a ụzọ na PowerShell?
1 2 |
$path = 'C:\Folder1\Folder2\Folder3\file.txt' Split-Path -Path (Split-Path -Path $path -Parent) -Leaf # Return Folder3 |
Olee otú laghachi naanị ikpeazụ ihe na a ụzọ na PowerShell?
1 2 |
$path = 'C:\Folder1\Folder2\Folder3\file.txt' Split-Path -Path $path -Leaf # Return file.txt |
Math
Olee otú depụta usoro ndị na-Sistem.Math na klas na PowerShell?
[System.Math] | Get-Member -Static -MemberType Method
Olee otú laghachi zuru uru na PowerShell?
[Math]::Abs(-12) #Returns 12
[Math]::Abs(-12.5) # Returns 12.5
Olee otú laghachi n’akuku onye-enweghị bụ kpọmkwem ọnụ ọgụgụ na PowerShell?
[Math]::ASin(1) #Returns 1,5707963267949
Olee otú laghachi n’uko uru na PowerShell?
[Math]::Ceiling(1.4) #Returns 2
[Math]::Ceiling(1.9) #Returns 2
Olee otú laghachi n’ala uru na PowerShell?
[Math]::Floor(1.4) #Returns 1
[Math]::Floor(1.9) #Returns 1
Olee otú laghachi eke (isi e) logarithm nke a kpọmkwem ọnụ ọgụgụ na PowerShell?
[Math]::Log(4) #Returns 1,38629436111989
Olee otú laghachi ukot 10 logarithm nke a kpọmkwem ọnụ ọgụgụ na PowerShell?
[Math]::Log10(4) #Returns 0,602059991327962
Olee otú laghachi kacha nke abụọ ụkpụrụ na PowerShell?
[Math]::Max(2,4) #Returns 4
[Math]::Max(-2,-4) #Returns -2
Olee otú laghachi na nke kacha nta nke abụọ ụkpụrụ na PowerShell?
[Math]::Min(2,4) #Returns 2
[Math]::Max(-2,-4) #Returns -4
Olee otú laghachi a ọnụ ọgụgụ zụlitere ka a kpọmkwem ike na PowerShell?
[Math]::Pow(2,4) #Returns 16
Olee otú laghachi a ntụpọ uru ka kacha nso integral uru na PowerShell?
[Math]::Round(3.111,2) #Returns 3,11
[Math]::Round(3.999,2) #Returns 4
Olee otú laghachi na akụkụ nke a kpọmkwem ntụpọ ọnụ ọgụgụ na PowerShell?
[Math]::Truncate(3.111) #Returns 3
[Math]::Truncate(3.999) #Returns 3
Olee otú laghachi na skware mgbọrọgwụ nke a kpọmkwem ọnụ ọgụgụ na PowerShell?
[Math]::Sqrt(16) #Returns 4
Olee otú laghachi na PI mgbe nile na PowerShell?
[Math]::Pi #Returns 3,14159265358979
Olee otú laghachi eke logarithmic isi (mgbe nile e) na PowerShell?
[Math]::E #Returns 2,71828182845905
Olee otú lelee ma ọ bụrụ na ọtụtụ bụ ọbụna ma ọ bụ iberibe na PowerShell?
[bool]($number%2)
Hashtables
Otú ike ihe efu gwakota-okpokoro na PowerShell?
$hashtable = @{}
$hashtable = New-Object -TypeName System.Collections.Hashtable
Otú ike a gwakota-okpokoro na ihe na PowerShell?
1 2 3 4 5 |
$hashtable = @{ 'Key1' = 'Value1' 'Key2' = 'Value2' 'Key3' = 'Value3' } |
Otú ike a gwakotao-kpokoro ota site isi / aha (nyere iwu ọkọwa okwu) na ihe na PowerShell?
1 2 3 4 5 6 7 |
$hashtable = [ordered]@{ 'Key1' = 'Value1' 'Key2' = 'Value2' 'Key3' = 'Value3' } $hashtable | Get-Member # System.Collections.Specialized.OrderedDictionary |
Olee ka ịgbakwunye ihe na (isi-uru ụzọ) ka a gwakota okpokoro na PowerShell?
$hashtable.Add('Key3', 'Value3')
Esi a kpọmkwem uru nke a gwakota-okpokoro na PowerShell?
$hashtable.Key1
$hashtable.Get_Item('Key1')
Esi opekempe uru nke a gwakota-okpokoro na PowerShell?
1 2 3 4 5 6 7 8 |
$hashtable = @{ 'Key1' = '1' 'Key2' = '2' 'Key3' = '3' } $hashtable.GetEnumerator() | Sort-Object -Property Value | Select-Object -First 1 $hashtable.GetEnumerator() | Sort-Object -Property Value -Descending | Select-Object -Last 1 |
Esi na kacha uru nke a gwakotao-kpokoro na PowerShell?
1 2 3 4 5 6 7 8 |
$hashtable = @{ 'Key1' = '1' 'Key2' = '2' 'Key3' = '3' } $hashtable.GetEnumerator() | Sort-Object -Property Value -Descending | Select-Object -First 1 $hashtable.GetEnumerator() | Sort-Object -Property Value | Select-Object -Last 1 |
Olee otú gbanwee ihe na a gwakota-okpokoro na PowerShell?
$hashtable.Set_Item('Key1', 'Value1Updated')
Esi wepụ ihe na a gwakota-okpokoro na PowerShell?
$hashtable.Remove('Key1')
Olee otú ikpochapụ a gwakota-okpokoro na PowerShell?
$hashtable.Clear()
Olee otú elele ọnụnọ nke a kpọmkwem isi / uru a gwakota-okpokoro na PowerShell?
$hashtable.ContainsKey('Key3')
$hashtable.ContainsValue('Value3')
Olee otú idozi site isi / uru a gwakota-okpokoro na PowerShell?
$hashtable.GetEnumerator() | Sort-Object -Property Name
$hashtable.GetEnumerator() | Sort-Object -Property Value -Descending
Arrays
Otú ike ihe efu n’usoro na PowerShell?
$array = @()
$array = [System.Collections.ArrayList]@()
Otú ike otu n’usoro na ihe na PowerShell?
$array = @('A', 'B', 'C')
$array = 'A', 'B', 'C'
$array = 'a,b,c'.Split(',')
$array = .{$args} a b c
$array = echo a b c
Olee ka ịgbakwunye ihe na otu n’usoro na PowerShell?
$array += 'D'
[void]$array.Add('D')
Olee otú gbanwee ihe na-n’usoro na PowerShell?
$array[0] = 'Z' # 1st item[0]
Olee otú ịlele size nke otu n’usoro na PowerShell?
$array = 'A', 'B', 'C'
$array.Length # Returns 3
Olee otú iji weghachite otu ihe / ọtụtụ / ihe niile dị otu n’usoro na PowerShell?
$array = @('A', 'B', 'C')
$array[0] # One item (A)
$array[0] + $array[2] # Several items (A,C)
$array # All items (A,B,C)
Esi wepụ efu ihe na otu n’usoro na PowerShell?
$array = @('A', 'B', 'C', '')
$array = $array.Split('',[System.StringSplitOptions]::RemoveEmptyEntries) | Sort-Object # A,B,C
Olee otú lelee ma ọ bụrụ na otu ihe dị otu n’usoro na PowerShell?
$array = @('A', 'B', 'C')
'A' | ForEach-Object -Process {$array.Contains($_)} # Returns True
'D' | ForEach-Object -Process {$array.Contains($_)} # Returns False
Esi achọta ndeksi ọnụ ọgụgụ nke otu ihe n’ime otu n’usoro na PowerShell?
$array = @('A', 'B', 'C')
[array]::IndexOf($array,'A') # Returns 0
Olee otú iji dozie ka nke ihe na-n’usoro na PowerShell?
$array = @('A', 'B', 'C')
[array]::Reverse($array) # C,B,A
Olee otú n’ịwa a random ihe site otu n’usoro na PowerShell?
$array | Get-Random
Olee otú idozi otu n’usoro na-arịgo / agbadata ụzọ na PowerShell?
$array = @('A', 'B', 'C')
$array | Sort-Object # A,B,C
$array | Sort-Object -Descending # C,B,A
Olee otú ịgụ ọnụ ọgụgụ nke ihe na-n’usoro na PowerShell?
$array.Count
Olee otú ịgbakwunye otu n’usoro ọzọ na PowerShell?
$array1 = 'A', 'B', 'C'
$array2 = 'D', 'E', 'F'
$array3 = $array1 + $array2 # A,B,C,D,E,F
Esi achọta duplicates site na n’usoro na PowerShell?
$array = 'A', 'B', 'C', 'C'
($array | Group-Object | Where-Object -FilterScript {$_.Count -gt 1}).Values # Returns C
Esi wepụ oyiri site na n’usoro na PowerShell?
$array = 'A', 'B', 'C', 'C'
$array = $array | Select-Object -Unique
$array # Returns A,B,C
Otú ike otu n’usoro na ihe malite na a nganiihu (“user01”, “user02”, … “user10”) na PowerShell?
$array = 1..10 | ForEach-Object -Process { "user$_" }
ACL
Olee otú depụta ACL nke AD ọrụ na PowerShell?
(Get-Acl -Path "AD:\$dn").Access
Olee otú depụta ACL nke a nchekwa na PowerShell?
(Get-Acl -Path C:\scripts).Access
1 |
((Get-Acl -Path "AD:\$dn").Access | Select-Object -Property IdentityReference | Where-Object -FilterScript {$_.IdentityReference -match 'Admin'} | Get-Unique | ForEach-Object -Process {$_.IdentityReference}).Value |
Variables
Gịnị bụ ihe ndị kasị data ụdị na PowerShell?
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 |
[bool]$variable = $true [byte]$variable = ('0x10') [char]$variable = 0x260E [datetime]$variable = Get-Date [decimal]$variable = 1.89 [double]$variable = 1.89 [float]$variable = 1.89 [guid]$variable = 'b19b2a2e-ce1b-4b62-844f-ac8829ffbe8f' [int16]$variable = -32767 [int32]$variable = -2147483647 [int64]$variable = -9223372036854775807 [string]$variable = 'test' [uint16]$variable = 32767 [uint32]$variable = 2147483647 [uint64]$variable = 9223372036854775807 |
Olee otú ịchọta kacha nta na kacha ụkpụrụ maka ụdị ụfọdụ variables na PowerShell?
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 |
[int] (integer) # int16 : MIN:-32768 MAX:32767 'MIN:{1:D} MAX:{0:D}' -f [int16]::MaxValue, [int16]::MinValue # int32 : MIN:-2147483648 MAX:2147483647 'MIN:{1:D} MAX:{0:D}' -f [int32]::MaxValue, [int32]::MinValue # int64 : MIN:-9223372036854775808 MAX:9223372036854775807 'MIN:{1:D} MAX:{0:D}' -f [int64]::MaxValue, [int64]::MinValue [uint] (u = unsigned, only positive numbers) # int16 : MAX:65535 'MAX:{0:D}' -f [uint16]::MaxValue # int32 : MAX:4294967295 'MAX:{0:D}' -f [uint32]::MaxValue # int64 : MAX:18446744073709551615 'MAX:{0:D}' -f [uint64]::MaxValue |
Olee otú nwalee dataụdị na PowerShell?
1 2 3 |
32 -is [int] $true -is [bool] 'a' -is [string] |
Otú ike a Lee-eriri agbanwe na PowerShelll?
1 2 3 4 5 6 7 8 9 10 11 12 13 |
# Without variable $hereString = @" My first name is Test My last name is Powershell "@ # With variable $firstName = 'Test' $lastName = 'Powershell' $hereString = @" My first name is ${firstName} My last name is ${lastName} "@ |
Otú ike a agbanwe na PowerShell?
$powershellGuru = 'Hello'
Otú ike a mgbe nile agbanwe na PowerShell?
Set-Variable -Name powershellGuru -Value 2015 -Option Constant