Mibvunzo ino yakaitirweyi Mibvunzo pamusoro pePowershell
Unokwanisa kubatsirikina munzira dzakasiyana siyana
- Kuisa mitemo muchinyorwa
- Kuti ukasire kuona mamiriro akaita mutemo wakati newakati
- Kuwedzera zivo pabasa rako
- Kuwana mitemo mitsva
- Kugadzirira bvunzo yebasa
Zvakawedzerwa |
2015/28/06
|
Munyori | powershell-guru.com |
Zvichiwanikwa | shona.powershell-guru.com |
Mapato |
75
|
Mibvunzo |
610
|
System
Ndingazive sei mhando yePowershell yandiri kushandisa?
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 } |
Ndingashandise sei Powershell neimwe mhando kuitira kuti zvizopindirane nemhando dzekare?
powershell.exe -Version 2.0
Ndingashandise sei Powershell yemhando yepasi (3.0 kana pamusoro) pazvinyorwa nePowershell?
#Requires -Version 3.0
Ndingawana sei mvumo yekuchinja zvinyorwa zvakaitwa nePowershell?
1 2 3 4 5 |
# Solution 1 #Requires -RunAsAdministrator # Solution 2 [bool]((whoami.exe /all) -match 'S-1-16-12288') |
Ndinoona sei maparamita pazvinyorwa nePowershell?
help -Name .\Get-ExchangeEnvironmentReport.ps1 -Full
Ndingawana sei ruzivo pamusoro pemunhu arikushanda nePowershell?
[Security.Principal.WindowsIdentity]::GetCurrent()
Ndingagadzira sei, kana kunatsiridza kana kuisa zvakare tsanangudzo izere nePowershell?
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 |
Ndingamisa sei zvinyorwa kwemaseconds mashanu kana kwemanitsi mashoma) nePowershell?
Start-Sleep -Seconds 5
Start-Sleep -Seconds 300 # 5 minutes
Ndingaziva sei nguva yakapedzesera kubatidzwa kombiyuta yangu nePowershell?
(Get-CimInstance -ClassName win32_operatingsystem).LastBootUpTime
Ndingawana sei ma’type accelerators’ with 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 |
Ndingatara sei zvirongwa zvekutangisisa nePowershell?
1 |
Get-WmiObject -Class Win32_StartupCommand | Sort-Object -Property Caption | Format-Table -Property Caption, Command, User -AutoSize |
Ndingabvisa sei chirongwa nePowershell?
1 2 |
$application = Get-WmiObject -Query "SELECT * FROM Win32_Product WHERE Name LIKE 'HP Recovery Manager'" $application.Uninstall() |
Ndingatora sei mufannanidzo wepeji recombuta yangu kana peji yandinnenge ndiri kushandira nePowershell?
Take-ScreenShot -Screen -File 'C:\scripts\screenshot.png' -Imagetype JPEG
Repository : Take-ScreenShot
Ndingaverenge sei tsamba dzangu ndichisandisa MSMQ nePowershell?
1 |
Get-WmiObject -Class Win32_PerfRawData_MSMQ_MSMQQueue -ComputerName $computer | Format-Table -Property Name, MessagesInQueue -AutoSize |
Ndingagadzira sei ‘Execution Policy” nePowershell?
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 |
Ndingagadzira sei nzira yekudimburira nePowershell
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() |
Ndinga isa kana kubvisa sei purogiramu pa’Taskbar’ nePowershell
1 2 3 4 |
$shell = New-Object -ComObject shell.application $program = $shell.Namespace($env:windir).Parsename('notepad.exe') $program.Invokeverb('TaskbarPin') $program.Invokeverb('TaskbarUnpin') |
Ndingavhura sei ‘Windows Explorer’ nePowershell?
[Diagnostics.Process]::Start('explorer.exe')
Invoke-Item -Path C:\Windows\explorer.exe
Ndingaronga sei madhiraivha emushina nePowershell?
Get-WmiObject -Class Win32_PnPSignedDriver
Get-WindowsDriver -Online -All
driverquery.exe
Ndingagadzira sei GUID nePowershell
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') |
Ndingaziva sei kune munhu anenge ari kushandisa Powershell panguva ipi neipi?
[System.IO.Path]::GetTempPath()
Ndingabatanidza sei path nechild path kuti zvive one path nePowershell
Join-Path -Path C:\ -ChildPath \windows
Ndingaronge sei ma cmdlets “Get,-*” nePowershell?
Get-Command -Verb Get
Ndingaronge sei ma ‘Special System Folders’ nePowershell
1 |
[System.Enum]::GetNames([System.Environment+SpecialFolder]) | ForEach-Object -Process { $_ + " [System.Environment]::GetFolderPath($_)" } |
Ndinga isa sei mafaira e ISO/VHD nePowershell?
Mount-DiskImage 'D:\ISO\file.iso' # ISO
Mount-DiskImage 'D:\VHD\file.vhd' # VHD
Ndingaona sei kuti ma .NET Framework versions akaiswa nePowershell akamira sei?
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 |
Ndingaziva sei kuti .NET Framework version 4.5 iripo yakaiswa nePowershell?
(Get-ItemProperty -Path 'HKLM:\Software\Microsoft\NET Framework Setup\NDP\v4\Full' -EA 0).Version -like '4.5*'
Ndingatangise nekumisa sei zvinyorwa zvinenge zvaitwa nePowershell?
Start-Transcript -Path 'C:\scripts\transcript.txt
Stop-Transcript
Ndingachinje sei dhayirekitori kuti riende pandinozosarudza nePowershell?
Set-Location -Path 'C:\scripts'
Ndingabvisa sei zviri pacombuta pangu nePowershell
Clear-Host
cls # Alias
Ndingachinja sei maratdziro anoita kombuyuta nePowershell?
Set-DisplayResolution -Width 1280 -Height 1024 -Force # Windows 2012
Ndingakudze ‘screen’ yangu sei nePowershell
mode.com 300
Ndingazive sei makuriro, (kupamhamha kana kureba) kwemupikicha nePowershell?
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 } |
Ndingawana sei ‘Windows Product Key’ nePowershell?
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
Ndingawana sei ‘% Processor Time” mu masekondi mashanu (kagumi) nePowershell
(Get-Counter '\Processor(_total)\% Processor Time' -SampleInterval 5 -MaxSamples 10).CounterSamples.CookedValue
Assemblies
Ndingaisa sei ma’Assemblies’ nePowershell?
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') |
Ndingaziva sei ma’.NET assemblies’ epanguva iyoyo akaiswa nePowershell?
1 2 3 4 5 |
# Check All [System.AppDomain]::CurrentDomain.GetAssemblies() # Check specific one [System.AppDomain]::CurrentDomain.GetAssemblies() | Where-Object -FilterScript { $_.FullName -like '*forms*' } |
Ndingawana sei GAC (Global Assembly Cache) nePowershell
1 |
(New-Object -TypeName Regex -ArgumentList '(?<=file:///)(.*)(?=\/GAC)', 'IgnoreCase').Match(([PSObject].Assembly.Evidence | Where-Object -FilterScript { $_.Value -ne $null }).Value).Value -replace '/', '\' |
Clipboard
Ndinga kopa sei zvinhu nePowershell?
1 |
Get-Process | clip.exe |
Ndingazowana zvinhu zvandambokopa sei nePowershell?
Add-Type -AssemblyName PresentationCore
[Windows.Clipboard]::GetText()
Hotfixes
Ndingaisa ma’hot fixes’ sei nePowershell?
Get-HotFix -ComputerName $computer
Ndingawana sei ma’hotfixes’ akaiswa pazuva rakati nerakati nePowershell?
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
Ndingaone sei kana ‘Hotfix’ yakaiswa nePowershell?
Get-HotFix -Id KB2965142
Ndingaisa sei ma ‘hotfixes’ pacombuta iri kure neni?
Get-HotFix -ComputerName $computer
Pagefile
Ndingawana sei ruzivo pamusoro pe ‘Pagefile’ nePowershell
Get-WmiObject -Class Win32_PageFileusage | Select-Object -Property Name, CurrentUsage, AllocatedBaseSize, PeakUsage, InstallDate
Ndingaziva sei saizi (MB) inodiwa pa’Pagefile nePowershell?
[Math]::Truncate(((Get-WmiObject -Class Win32_ComputerSystem).TotalPhysicalMemory) / 1MB) * 1.5
Ndingagadzira sei ‘Pagefile’ (4096 MB) pa D drive’ nePowershell?
1 2 3 4 5 |
Set-WmiInstance -Class Win32_PageFileSetting -Arguments @{ Name = 'D:\pagefile.sys' InitialSize = 4096 MaximumSize = 4096 } |
Ndingabisa sei ‘Pagefile pa C drive’ nePowershell?
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
Ndingazive sei kudimburwa dimburwa kwe ‘drive’ nePowershell?
1 |
$drive = Get-WmiObject -Class Win32_Volume -Filter "DriveLetter = 'c:'" $defragReport = $drive.DefragAnalysis() $defragReport.DefragAnalysis |
Ndingazive sei dzvimbo iri pa ma ‘drives’ angu nePowershell?
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
Ndingavhur ase faira nePwershell?
Invoke-Item -Path 'C:\scripts\file.txt'
.'C:\scripts\file.txt'
Ndingaverenga sei faira rangu nePowershell?
Get-Content -Path 'C:\scripts\file.txt'
gc "C:\scripts\file.txt" # Alias
Ndinganyora sei zvandawana kufaira ndichishandisa Powershell?
'Line1', 'Line2', 'Line3' | Out-File -FilePath 'C:\scripts\file.txt'
'Line1', 'Line2', 'Line3' | Add-Content -Path file.txt
Ndingawana sei zita rizere rechinyorwa chandiri kushandisa nePowershell?
$MyInvocation.MyCommand.Path
Ndingatsindiridze sei mafaira nePowershell?
Add-Type -AssemblyName 'System.IO.Compression.Filesystem'
[System.IO.Compression.ZipFile]::CreateFromDirectory($folder,$fileZIP)
Ndingavhura sei mafaira andambotsindira nePowershell
Add-Type -AssemblyName 'System.IO.Compression.Filesystem'
[System.IO.Compression.ZipFile]::ExtractToDirectory($fileZIP, $folder)
Ndinowona sei mafaira andatsindira nePowershell?
Add-Type -AssemblyName 'System.IO.Compression.Filesystem'
[System.IO.Compression.ZipFile]::OpenRead($fileZIP)
Ndinoratidza sei saizi refaira muma KB nePowershell?
(Get-ChildItem -Path .\winsrv.dll).Length /1KB
(Get-ChildItem -Path .\winsrv.dll).Length /1MB
(Get-ChildItem -Path .\winsrv.dll).Length /1GB
Ndinowana sei mafaira akakura kana madiki ku 1GB nePowershell?
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} |
Ndingaratidza sei zita refaira ndisingashandise tambanudzo nePowershell?
[System.IO.Path]::GetFileNameWithoutExtension('C:\Windows\system32\calc.exe') # Return calc
Ndinoratidza sei tambanudzo yefaira nePowershell?
[System.IO.Path]::GetExtension('C:\scripts\file.txt') # Return .txt
Ndinoziva sei mhando yefaira nePowershell?
1 2 |
(Get-Item -Path C:\Windows\System32\calc.exe).VersionInfo.FileVersion [System.Diagnostics.FileVersionInfo]::GetVersionInfo('C:\Windows\system32\calc.exe').FileVersion |
Ndinowana sei hashi yefaira nePowershell?
(Get-FileHash $file).Hash
Ndinowana mhinduro kana ndasanganisa MD5/SHA1 yefaira nePowershell?
Get-FileHash $file -Algorithm MD5
Get-FileHash $file -Algorithm SHA1
Ndinoratidza sei mafaira anenge akahwandiswa nePowershell?
1 2 3 4 5 |
# Display only hidden files Get-ChildItem -Hidden -File # Display all files (including hidden files) Get-ChildItem -Force -File |
Ndinowona sei kana faira riine tambanudzo nePowershell?
1 |
[System.IO.Path]::HasExtension('C:\hiberfil.sys') |
Ndinogadzira sei faira kuti rive rekuverenga bedzi nePowershell?
Set-ItemProperty -Path .\file.txt -Name IsReadOnly -Value $true
Ndinochinja sei “LastWriteTime” kuti ive resvondo yakapera pafaira nePowershell?
Set-ItemProperty -Path .\file.txt -Name LastWriteTime -Value ((Get-Date).AddDays(-7))
If not working, use Nirsoft tool: BulkFileChanger.
Ndinogadzira sei faira idzva nePowershell?
New-Item -ItemType File -Path 'C:\scripts\file.txt' -Value 'FirstLine'
Ndinopa zit aidzva sei kufaira nePowershell?
Rename-Item -Path 'C:\scripts\file.txt' -NewName 'C:\scripts\powershellguru2.txt'
Ndingamazita manyowani kumafaira akawanda panguva imwe sei nePowershell?
Get-ChildItem -Path C:\scripts\txt | Rename-Item -NewName { $_.Name -replace ' ', '_' }
Ndingadzima sei faira nePowershell?
Remove-Item -Path 'C:\scripts\file.txt'
Ndingaratidza sei mitsetse gumi yekupedzisira yefaira nePowershell?
Get-Content -Path 'C:\scripts\log.txt' -Tail 10
Ndingavhura sei mafaira akawanda akaiswa muforodha nePowershell?
Get-ChildItem -Path 'C:\scripts\Modules' | Unblock-File
Ndinobvisa sei mitsara isina zvinhu pafaira nePowershell?
(Get-Content -Path file.txt) | Where-Object -FilterScript {$_.Trim() -ne '' } | Set-Content -Path file.txt
Ndingawana sei kuti faira riripo zveshuwa nePowershell?
1 |
Test-Path -Path 'C:\Windows\notepad.exe' # Return True |
Ndingawana sei faira idzva kana tsaru pamafaira ari muforodha nePowershell?
1 2 |
Get-ChildItem | Sort-Object -Property CreationTime | Select-Object -Last 1 # Newest Get-ChildItem | Sort-Object -Property CreationTime | Select-Object -First 1 # Oldest |
Ndinobvisa sei mitsetse yakadzokorodzwa mufaira nePowershell?
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 |
Ndingawana sei mafaira akagadzirwa panguva inoita mwedzi kana kupfuura muforodha nePowershell?
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 |
Ndingawana sei mafaira akagadirwa munguva inoita gore kana kupfuura nePowershell?
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 |
Ndingatumira sei huremu hwe zvisiyanwa kufaira nePowershell?
Set-Content -Path file.txt -Value $variable
Ndingaverenge sei huhwandu hwemafaira (*.txt) muforodha nePowershell?
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 |
Ndingatsvage sei tambo mukati memafaira akawanda nePowershell?
Select-String -Path 'C:\*.txt' -Pattern 'Test'
Ndingaratidza sei mutsara wekutanga kana kuguma nepowershell?
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 |
Ndingaratidza mutsetse wemufaira wandiri kuda nePowershell?
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 |
Ndingaverenge sei mitsetse yemufaira nePowershell?
1 2 |
'Line1', 'Line2', 'Line3' | Out-File -FilePath file.txt (Get-Content -Path .\file.txt | Measure-Object -Line).Lines # Returns 3 |
Ndingaverenge sei mazwi kana mavara ari mufaira nePowershell?
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 |
Ndingavhura sei faira nePowershell?
Invoke-WebRequest -Uri 'http://www.nirsoft.net/utils/searchmyfiles.zip' -OutFile 'C:\tools\searchmyfiles.zip'
Ndingaratidza sei nzira izere yefaira nePowershell?
Resolve-Path -Path .\script.ps1 # Return C:\Scripts\script.ps1
Copy
Ndinga kopa sei faira kuforodha nePowershell?
Copy-Item -Path 'C:\source\file.txt' -Destination 'C:\destination'
Ndingakopa sei faira rimwechete kumaforodha akawanda nePowershell?
1 2 |
$destination = 'C:\destination\Folder1', 'C:\destination\Folder2' $destination | Copy-Item -Path 'C:\source\file.txt' -Recurse -Destination {$_} |
Ndingakopa sei mafaira akawanda kuisa ku forodha rimwe nePowershell?
Get-ChildItem -Path 'C:\source' -Filter *.txt | Copy-Item -Destination 'C:\destination'
Active Directory
Domain & Forest
Ndingawana sei ‘Global Catalog servers’ mudirekitori riri kushanda nePowershell?
[System.DirectoryServices.ActiveDirectory.Forest]::GetCurrentForest().GlobalCatalogs
Ndingawana sei nzvimbo mudirekitori riri kushanda nePowershell?
[System.DirectoryServices.ActiveDirectory.Forest]::GetCurrentForest().Sites
Ndingaziva sei kuti domain randiri kushandisa riri kushanda sei nePowershell?
(Get-ADDomainController).HostName
Ndingawana sei nzvimbo dzose dziri kubata domain rangu Nepowershell?
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} |
Ndingawana sei pari kukundikana maAD replication nePowershell?
Get-ADReplicationFailure dc02.domain.com # Windows 8 and 2012
Ndingawana sei nguva inoshanda ‘tombstone’ musango re direkitori randiri kushandisa nePowershell?
1 |
(Get-ADObject -Identity "cn=Directory Service,cn=Windows NT,cn=Services,$(([adsi]('LDAP://RootDSE')).configurationNamingContext)" -Properties tombstonelifetime).tombstonelifetime |
Ndingawana sei ruzivo pamusoro pesango/domain mudirekirori randiri kushandisa nePowershell?
1 2 |
Get-ADDomain domain.com Get-ADForest domain.com |
Ndingawana sei nzira dzezvinyorwa zvadzimwa mudirekitori nePowershell?
(Get-ADDomain).DeletedObjectsContainer
Ndinomutsa sei bhinhi reAD mudirekitori nePowershell?
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' |
Ndinodzosa sei AD Account kubva mubhini mudhayirekitori nePowershell?
Get-ADObject -Filter 'samaccountname -eq "powershellguru"' -IncludeDeletedObjects | Restore-ADObject
Ndinowana seibasa re FSMO nePowershell?
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 |
Ndinobatanidza sei ma’domain controller’ nePowershell?
Get-ADUser -Identity $user -Server 'serverDC01'
Ndinowona sei pa sevha pandiri nePowershell?
1 2 |
($env:LOGONSERVER).Substring(2) ([System.Environment]::GetEnvironmentVariable('logonserver')).Substring(2) |
Ndinoita sei ‘gpupdate’ pakombiyuta nePowershell?
Invoke-GPUpdate -Computer $computer -Force -RandomDelayInMinutes 0 # Windows 2012
Groups
Ndinogadzira sei bato idzva mudhayirekitori nePowershell?
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' |
Ndinobvisa sei bato mudhayirekitori nePowershell?
Remove-ADGroup -Identity 'PowershellGuru'
Ndinoisa sei mumwe munhu mubato redhayirekitori nePowershell?
Add-ADGroupMember "Powershell Guru" -Members powershellguru
Ndinobvisa munhu mubato riri mudhayirekitori nePowershell?
Remove-ADGroupMember 'Powershell Guru' -Members powershellguru
Ndinowona sei mabato asina vanhu mudhayirekitori nePowershell?
Get-ADGroup -Filter * -Properties Members | Where-Object -FilterScript {-not $_.Members}
Ndinoverenga sei mabato asina vanhu mudhayirekitori nePowershell?
(Get-ADGroup -Filter * -Properties Members | Where-Object -FilterScript {-not $_.Members}).Count
ndinowana sei vanhu vari mubato redhayirekitori nePowershell?
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' |
Ndingawana sei vanhu vari mubato vanoita zvakafanana mudhayirekitori nePowershell?
1 2 |
Get-ADGroupMember 'Powershell Guru' -Recursive | ForEach-Object -Process {$_.DistinguishedName} Get-ADGroupMember 'Powershell Guru' -Recursive | ForEach-Object -Process {$_.SamAccountName} |
Ndingaverenga sei vanhu vari mubato rimwe vane maitiro akafana kana akasiyana nePowershell?
1 2 |
(Get-ADGroupMember 'Powershell Guru' | ForEach-Object -Process {$_.Samaccountname}).Count (Get-ADGroupMember 'Powershell Guru' -Recursive | ForEach-Object -Process {$_.Samaccountname}).Count |
Users
Ndingashandisa sei “wildcard’ mufirita ye “Get-ADUser” mudhayirekitori nePowershell?
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 |
Ndingabvisa sei munhu kuenda kune imwe OU mudhayirekitori nePowershell?
Move-ADObject -Identity $dn -TargetPath 'OU=myOU,DC=domain,DC=com'
Ndingawana sei zvinhu zvose zvakabatanidzwa pamwe nePowershell?
Get-ADGroup -LDAPFilter "(member:1.2.840.113556.1.4.1941:=$($dn))"
Ndingawana sei zita rekudimburira rezvinhu zvose zvemunhu nePowershell?
(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 |
Ndinga chinja sei nhoroondo, hofisi kana nhare remunhu mudhayirekitori nePowershell?
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 |
Ndingakiyinura sei akaundi yemunhu mudhayirekitori nePowershell?
Unlock-ADAccount $samAccountName
Ndinga vhura kana kuvhara sei akaundi mudirekitori nePowershell?
1 2 |
Disable-ADAccount $samAccountName Enable-ADAccount $samAccountName |
Ndingamvisa sei akaundi mudhayirekitori nePowershell?
Remove-ADUser $samAccountName
Ndingaisa sei pasiwedhi patsva muakaundi yemunhu mudhayirekitori nePowershell?
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 |
Ndingaisa pasiwedhi matsva kuvanhu vakawanda mjudhayirekitori nePowershell?
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 |
Ndingawana sei muridzi wefaira muidhayirekitori nePowershell?
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 |
Ndingawana sei OU (organizational unit) yemunhu mudhayirekitori nePowershell?
[regex]::match("$((Get-ADUser $user -Properties DistinguishedName).DistinguishedName)",'(?=OU=)(.*\n?)').value
Ndingawana sei maakaundi amiswa kushanda mudhayirekitori nePowershell?
1 2 |
Search-ADAccount -AccountDisabled Get-ADUser -Filter {Enabled -ne $true} |
Ndingawana sei maakaundi asisashande mudhayirekitori nePowewrshell?
Search-ADAccount -AccountExpired
Ndingawana sei maakaundi avhvarwa mudhairekitori nePowershell?
Search-ADAccount -LockedOut
Ndingawana sei SID ye akaundi mudhairekitori nePowershell?
(Get-ADUser $user -Properties SID).SID.Value
Ndingachinja sei zita rinoshandiswa kuenda ku SID mudhairekitori nePowershell?
1 2 |
$user = New-Object -TypeName System.Security.Principal.NTAccount -ArgumentList ('DOMAIN', 'user') $SID = ($user.Translate([System.Security.Principal.SecurityIdentifier])).Value |
Ndingachinja sei SID kuita zita rekushandisa mudhairekitori nePowershell?
1 2 |
$SID = New-Object -TypeName System.Security.Principal.SecurityIdentifier -ArgumentList ('SID') $user = ($SID.Translate( [System.Security.Principal.NTAccount])).Value |
Ndinga kamura sei zita rakapihwa akaundi mudhairekitori nePowershell?
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" |
Ndingawana sei zita rakagadzirwa kana kuchinjwa akaundi mudhairekitori nePowershell?
Get-ADUser -Identity $user -Properties whenChanged, whenCreated | Format-List -Property whenChanged, whenCreated
Ndingaratidza zvino sarudzwa kana zvinotofanira kuitwa nemunhu mudhayirekitori nePowershell?
1 2 3 |
$schema = [DirectoryServices.ActiveDirectory.ActiveDirectorySchema]::GetCurrentSchema() $schema.FindClass('user').mandatoryproperties | Format-Table $schema.FindClass('user').optionalproperties | Format-Table |
Ndingawana sei LDAP yemunhu mudhairekitori nePowershell?
1 2 3 4 |
$searcher = New-Object -TypeName DirectoryServices.DirectorySearcher -ArgumentList ([ADSI]'') $searcher.Filter = "(&(objectClass=user)(sAMAccountName= $user))" $searcher = $searcher.FindOne() $pathLDAP = $searcher.Path |
Ndingachinja sei CN (Canonical Name) remunhu mudhairekitori ne Powershell?
Rename-ADObject $((Get-ADUser $user -Properties DistinguishedName).DistinguishedName) -NewName 'Test Powershell'
Ndingawana sei panotangira Organizational Unit (OU) remunhu mudhairekitori nePowershell?
1 2 |
$dn = (Get-ADUser $user -Properties DistinguishedName).DistinguishedName $parent = $dn.Split(',',2)[1] |
Ndingawana sei munhu akagadzira akaundi mudhairekitori nePowershell?
1 2 |
$dn = (Get-ADUser $user -Properties DistinguishedName).DistinguishedName $owner = (Get-Acl -Path "AD:$dn").Owner |
Ndingapindurudza sei PwdLastSet yemunhu mudhairekitori nePowershell?
1 2 3 4 5 |
# Solution 1 [DateTime]::FromFileTime((Get-ADUser $user -Properties pwdLastSet).pwdLastSet) # Solution 2 w32tm /ntte 130787549514737594 |
Computers
Ndingaongorore sei nzira iri pakati pekombuita yepandiri ne ‘domain’ nePowershell?
Test-ComputerSecureChannel
Ndingagadzirisa sei nzira yakachengetedzeka pakati pekombuta yandiri nedomain nePowershell?
Test-ComputerSecureChannel -Repair
Ndingamisa sei kombuyuta kushanda mudhayirekitori nePowershell?
Disable-ADAccount $computer
Ndingawana sei makombuyuta ane mashandiro akadayi mudhayirekitori nePowershell
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)
Ndingagadzira sei Organizational Unit (OU) mudhayirekitori nePOwershell?
New-ADOrganizationalUnit -Name 'TEST' -Path 'DC=domain,DC=com'
Ndingawana sei zivo pamusoro peOrganizational Unit (OU) nePowershell?
Get-ADOrganizationalUnit 'OU=TEST,DC=domain,DC=com' -Properties *
Ndingachinje sei tsanangudzo yeOrganizational Unit mudhayirekitori nePowershell?
Set-ADOrganizationalUnit 'OU=TEST,DC=domain,DC=com' -Description 'My description'
Ndingatendera kana kurambidza sei Organizationa Unit kubva mukudzimika munhu asingade?
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 |
Ndingabvumidza sei kudzimika manga manga kweOrganizational Unit (OU) mudhayirekitori nePowershell?
1 |
Get-ADOrganizationalUnit -Filter * -Property ProtectedFromAccidentalDeletion | Where-Object -FilterScript { $_.ProtectedFromAccidentalDeletion -eq $false } | Set-ADOrganizationalUnit -ProtectedFromAccidentalDeletion $true |
Ndingabvisa sei Organizational Unit (OU) rakachengetwa kubva mukudzimwa manga manga
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 |
Ndingataara sei maOrganizational Units asina zvinhu nePowershell?
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 } |
Ndingawana sei minija webato nePowershell?
(Get-ADGroup $dn -Properties Managedby).Managedby
Regex (Regular Expression)
Ndingawana sei kero yeIP v4 (80.80.228.8) ndichishnadisa Regex nePowershell?
$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
Ndingawana sei kero yeMAC (C0-D9-62-39-61-2D) nechinopatsanura “_” neRegex nePowershell?
$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
Ndingawana sei kero ye MAC (c0:d9:62:39:61:2D) nechinopatsanura neRegex nePowershell?
$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
Ndingawana sei zuva (10/02/2015) neRegex nePowershell?
$example = 'The date is 10/02/2015'
$date = [regex]::match($example,'(\d{2}\/\d{2}\/\d{4})').value
Ndingawana sei URL (www.powershell-guru.com) neRegex nePowershell?
$example = 'The URL is www.powershell-guru.com'
$url = [regex]::match($example,'[a-z]+[:.].*?(?=\s)').value
Ndingawana sei email’ (userdomain.com) neRegex nePowershell?
$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
Ndingawana sei ‘guru” kubva mustring example neRegex nePowershell?
$example = 'www.powershell-guru.com'
[regex]::match($example,'(?<=-)(.*\n?)(?=.com)').value
Ndingawana sei “guru.com” kubva mustring example neRegex nePowershell?
$example = 'www.powershell-guru.com'
[regex]::match($example,'(?<=-)(.*\n?)(?<=.)').value
Ndingawana sei “powershell-guru.com” kubva mustring nePowershell?
$example = 'www.powershell-guru.com'
[regex]::match($example,'(?<=www.)(.*\n?)').value
Ndingawana sei “123” kubva mustring example neRegex nePowershell?
$example = 'Powershell123'
[regex]::match($example,'(\d+)').value
Ndingawana sei $ (saini yedora) kubva mustring example?
$example = 'Powershell`$123'
[regex]::match($example,'(\$)').value
Ndingachinjanise saini (*.com) ne (*.fr) mustring example?
$example = 'www.powershell-guru.com'
[regex]::Replace($example, '.com','.fr')
Ndingabuda sei kubva pastring neRegex nePowershell?
[regex]::Escape('\\server\share')
Memory
Ndingamanikidza sei chikwata chezvakamboitwa kubva kunorasirwa nePowershell
[System.GC]::Collect()
[System.GC]::WaitForPendingFinalizers()
Ndingawana sei saizi yeRAM yekomboyuta nePowershell?
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
Ndinowana sei zuva ranhasi nePowershell?
Get-Date
[Datetime]::Now
Ndingaratidza sei zuva zvakasiyana siyana nePowershell?
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 |
Ndingashandura sei zuva (Datetime) kuenda kuzuva(string) nePowershell?
$datetimeToString = '{0:dd/MM/yy}' -f (Get-Date 30/01/2015)
$datetimeToString = (Get-Date 31/01/2015).ToShortDateString()
Ndingashadura sei zuva (Date) kuenda ku (Datetime) nePowershell?
$stringToDatetime = [Datetime]::ParseExact('30/01/2015', 'dd/MM/yyyy', $null)
Ndingawone sei musiyano (hweuwandu hwemazuva, maawa, maminitsi kana masekondi) pakati pemazuva maviri nePowershell?
(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
Ndingayenzanise sei mazuva maviri nePowershell?
(Get-Date 2015-01-01) -lt (Get-Date 2015-01-30) # True
(Get-Date 2015-01-01) -gt (Get-Date 2015-01-30) # False
Ndingaronge sei mazuva akasiyana siyana se “Datetime” nePowershell?
$arrayDate | Sort-Object -Property {$_ -as [Datetime]}
Ndingatanga nekumisa sei wachi nePowershell
$chrono = [Diagnostics.Stopwatch]::StartNew()
$chrono.Stop()
$chrono
Ndingawane sei kuti musi wechingani NePowershell?
(Get-Date).DayOfWeek #Sunday
Ndingawane sei kuti zuro waiva musi waani nePowershell?
(Get-Date).AddDays(-1)
Ndingawane sei kuti mumwedzi mune mazuva mangani (muna Kukadzi 2015) nePowershell?
[DateTime]::DaysInMonth(2015, 2)
Ndinoziva sei kuti Kukadzi wegore rino akareba nePowershell?
[DateTime]::IsLeapYear(2015)
Ndinotara sei mapazi akasiyana siyana enguva nePowershell?
[System.TimeZoneInfo]::GetSystemTimeZones()
Networking
Ndinga isa code kana kuvhura kodhi ye URL seyi nePowershell?
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 |
Zvimvwe zvinoenderana ne ‘native network commands’ ndezvipi nePowershell?
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 |
Ndingawana kero dze IP sei nePowershell?
Get-NetIPAddress # Windows 8.1 & Windows 2012
Get-NetIPConfiguration # Windows 8.1 & Windows 2012
Ndingakonesa kuti kero ye IP ishande sei nePowershell?
1 |
New-ItemProperty -Path 'HKLM:\SYSTEM\CurrentControlSet\Services\Tcpip6\Parameters' -Name 'DisabledComponents' -Value '0xFFFFFFFF' -PropertyType"DWORD" # Reboot required |
Ndingaone sei chokwadi chekero yeIP v$ (IPV4) nePowershell?
if([ipaddress]'10.0.0.1'){'validated'}
Ndingawana sei kero yekunze yeIP nePowershell?
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 } |
Ndingawana sei zita remuridzi we kero yeIP nePowershell?
([System.Net.Dns]::GetHostEntry($IP)).Hostname
Ndingawama sei kero yeIP kubva kuzita romuridzi?
([System.Net.Dns]::GetHostAddresses($computer)).IPAddressToString
Ndingawana sei FQDN kubva kuzita remuridzi nePowershell?
[System.Net.Dns]::GetHostByName($computer).HostName
1 |
Get-WmiObject -Class Win32_NetworkAdapterConfiguration | Format-Table -Property Description, IpAddress, IPSubnet, DefaultIPGateway, DNSServerSearchOrder |
Ndingawana sei kero ye MAC nePowershell?
Get-CimInstance win32_networkadapterconfiguration | Select-Object -Property Description, Macaddress
Get-WmiObject -Class win32_networkadapterconfiguration | Select-Object -Property Description, Macaddress
Ndingateveredza nzira yekombuyuta sei nePowershell?
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) |
Ndingawona seyi kana kombuyuta iine indaneti nePowershell?
1 |
[Activator]::CreateInstance([Type]::GetTypeFromCLSID([Guid]'{DCB00C01-570F-4A9B-8D69-199FDBA5723B}')).IsConnectedToInternet |
Ndinoita sei kana ndichida kutsvaga “ndiyani”/whois yewebusaiti nePowershell?
$whois = New-WebServiceProxy 'http://www.webservicex.net/whois.asmx?WSDL'
$whois.GetWhoIs('powershell-guru.com')
Ndingawane sei ruzivo pa kero yeIP yeruzhinji (Geolocation) nePowershell?
1 2 |
$externalIP = (Invoke-WebRequest -Uri 'myexternalip.com/raw').Content $detailsIP = ([xml](Invoke-WebRequest -Uri "http://freegeoip.net/xml/$externalIP" -UseBasicParsing).Content).Response |
Ndingawone sei kana poti yakavhurika kana kuvharwa nePowershell?
New-Object -TypeName Net.Sockets.TcpClient -ArgumentList $computer, 135
Ndingaita ‘tracert’ sei nePowershell?
Test-NetConnection www.google.com -TraceRoute
Ndingagadzira sei neetiweki yepamba nePowershell?
Get-NetAdapter | Format-Table -Property Name, InterfaceDescription, ifIndex -AutoSize # Windows 8.1
Set-NetConnectionProfile -InterfaceIndex 6 -NetworkCategory Private
Ndinoratidza sei mabatanidzirwo akaitwa TCP poti nePowershell?
netstat.exe -ano
Get-NetTCPConnection #Windows 8 and 2012
Ndingapfupikisa sei URL yakareba kuiita kadiki diki nePowershell?
$url = 'www.powershell-guru.com'
$tiny = Invoke-RestMethod -Uri "http://tinyurl.com/api-create.php?url=$url"
Ndingawane sei maitirwo akaitwa Proxy nePowershell?
Get-ItemProperty -Path HKCU:"Software\Microsoft\Windows\CurrentVersion\Internet Settings"
DNS
Ndingaone sei DNS cache pakombuyuta yepedo nePowershell?
ipconfig.exe /displaydns
Get-DnsClientCache #Windows 8 and 2012
Ndingabvisa sei DNS cache pakombuyuta yepedo nePOwershell?
ipconfig.exe /flushdns
Start-Process -FilePath ipconfig -ArgumentList /flushdns -WindowStyle Hidden
Clear-DnsClientCache #Windows 8 and 2012
Ndingabvisa sei DNS cache pakombuyuta yekure nePowershell?
Invoke-Command -ScriptBlock {Clear-DnsClientCache} -ComputerName computer01, computer02
Ndingaverenga sei zvinyorwa zvemafaira epo nePowershell?
Get-Content -Path 'C:\Windows\system32\drivers\etc\hosts'
Password
Ngingaisa sei pasiwedhi chiripo ripocho nePowershell?
[Reflection.Assembly]::LoadWithPartialName('System.Web')
[System.Web.Security.Membership]::GeneratePassword(30,2)
Ndingachinja sei pasiwedhi yemutariri weepanzvimbo ipapo kusevha iri kure naye
$admin = [ADSI]('WinNT://server01/administrator,user')
$admin.SetPassword($password)
$admin.SetInfo()
Ndingawane sei musi unomira kushanda pasiwedhi mudhairekitori nePowershell?
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
Ndingatara sei mapirinta esevha rimwe nePowershell?
Get-WmiObject -Query 'Select * From Win32_Printer' -ComputerName $computer
Ndingatara sei mapoti esevha rimwe nePowershell?
Get-WmiObject -Class Win32_TCPIPPrinterPort -Namespace 'root\CIMV2' -ComputerName $computer
Ndingachinja sei zvakanyorwa kana panowanikwa pirinta nePowershell
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() |
Ndingabvisa sei basa rose ranga ratumirwa kupirinta nePowershell?
$printer = Get-WmiObject -Class win32_printer -Filter "Name='HP Deskjet 2540 series'"
$printer.CancelAllJobs()
Ndingatumira sei peji rekuongorora pirinta nePowershell?
$printer = Get-WmiObject -Class win32_printer -Filter "Name='HP Deskjet 2540 series'"
$printer.PrintTestPage()
Ndingawane sei miraini yepirinta nePowershell?
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
Ndingatara sei mapato emaregistiri nePowershell
Get-ChildItem -Path Registry::
Ndingawane sei udzamo uye mhando dzemaregistiri nePowershell?
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) } } } |
Ndingatara sei makiyi nemakiyi anotevera eregistiri nePowershell?
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:\' |
Ndingatara sei makiyi nemakiyi anotevera eregistiri nenzira indzokororeka?
Get-ChildItem -Path 'HKLM:\SYSTEM' -Recurse -ErrorAction SilentlyContinue
Ndingawana sei makiyi anotevera aine zita rawo nePowershell?
Get-ChildItem -Path 'HKLM:\SOFTWARE' -Include *Plugin* -Recurse -ErrorAction SilentlyContinue
Ndingadzosa sei zita bedzi remakiyi anotevera eregistiri nePowershell?
(Get-ChildItem -Path 'HKLM:\SYSTEM').Name # Return HKEY_LOCAL_MACHINE\SYSTEM\ControlSet
Get-ChildItem -Path 'HKLM:\SYSTEM' -Name # Return ControlSet
Ndingatara sei udzamo we registiri nePowershell?
Get-ItemProperty -Path 'HKLM:\SOFTWARE\Microsoft\Windows NT\CurrentVersion'
Ndingaverenga sei regisitiri iri nePowershell
(Get-ItemProperty -Path 'HKLM:\SOFTWARE\Microsoft\Windows NT\CurrentVersion').ProductName
ndingaverenga sei udzamo weregisitiri iri pakombuyuta iri kure nePowershell?
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
Ndingagadzira sei regisitiri nyowani nePowershell?
New-Item -Path 'HKCU:\Software\MyApplication'
Ndingagadzira sei udzamo weregisitiri nePowershell?
New-ItemProperty -Path 'HKCU:\Software\MyApplication' -Name 'Version' -Value '1.0'
Ndingachinja sei udzamo weregisitiri riripo nePowershell?
Set-ItemProperty -Path 'HKCU:\Software\MyApplication' -Name 'Version' -Value '2.0'
Delete
Ndingadzime sei udzamo weregisitiri nePowershell?
Remove-ItemProperty -Path 'HKCU:\Software\MyApplication' -Name 'Version'
Ndingadzime sei kiyi yeregisitiri nePowershell?
Remove-Item -Path 'HKCU:\Software\MyApplication' -Force
Test
Ndingaongorore sei kuti kiyi yerigisitiri iripo nePowershell?
Test-Path -Path 'HKCU:\Software\MyApplication'
Ndingaongorore sei kuti udzamo weregisitiri huripo nePowershell?
(Get-Item -Path 'HKCU:\Software\MyApplication').GetValueNames() -contains 'Version'
Strings
Ndingabvisa sei mavara kana masaini e’white-space” kubva panotangira ‘string’ nePowershell?
$string = ' PowershellGuru'
$string = $string.TrimStart()
Ndingabvisa sei mavara kana masaini kunoperera ‘string’ nePowershell?
$string = 'PowershellGuru '
$string = $string.TrimEnd()
Ndingabvisa sei mavara kana masaini kunotangira kana kuperera ‘string’ nePowershell?
$string = ' PowershellGuru '
$string = $string.Trim()
Ndingachinja sei ‘string’ kuti ive nemavara makuru nePowershell?
$string = 'powershellguru'
$string = $string.ToUpper()
Ndingachinja sei ‘string’ kuti ive nemavara maduku nePowershell?
$string = 'POWERSHELLGURU'
$string = $string.ToLower()
Ndingasarudza sei ‘substring’ Powershell ye ‘string’ “PowerShellGuru” nePowershell?
$string.Substring(0,10)
Ndingasarudza sei ‘substring’ “Guru” ye string’ “PowerShellGuru” nePowershell?
$string.Substring(10)
Ndingasarudza sei nhamba dzinoti “123” dze ‘Powershell” nePowershell?
$string = 'Powershell123Guru'
[regex]::match($string,'(\d+)').value
Ndingawana sei chikamu che zero-based che “Guru” chestring “PowerShellGuru” nePowershell?
$string.IndexOf('Guru') # 10
Ndingazive sei kana ‘string’ isina basa kana isina chinhu nePowershell?
$string = $null
$string = ''
[string]::IsNullOrEmpty($string)
Ndingazive sei kana ‘string’ isina basa, isina chinhu kana iiine ‘white space characters’ nePowershell
$string = $null
$string = ''
$string = ' '
[string]::IsNullOrWhiteSpace($string)
Ndingazive sei kana ‘string’ iine vara rakati nePowershell?
$string = 'PowershellGuru'
$string.Contains('s')
[regex]::match($string,'s').Success
Ndingadzosa seihurefu hwe ‘string’ nepOwershell?
$string.Length
Ndingabatanidza sei ma ‘string’ maviri nePowershell?
1 2 3 4 5 6 7 |
# Solution 1 $string1 + $string2 # Solution 2 $string1 = 'Powershell' $string2 = 'Guru' [string]::Concat($string1,$string2) |
Ndingamechese sei chiumbiridzo chimwe kana zvakawanda “[ ]”mu ‘string’ nePowershell?
$string = '[PowershellGuru]'
$string -match '\[' # Only 1
$string -match '\[(.*)\]' # Several
Ndingamechese sei chiumbiridzo chimwe kana zvakawanda “( )” mustring nePowershell?
$string = '(PowershellGuru)'
$string -match '\(' # Only 1
$string -match '\((.*)\)' # Several
Ndingamechese sei chiumbiridzo chimwe kana zvakawanda “{ }” mustring nePowershell?
$string = '{PowershellGuru}'
$string -match '\{' # Only 1
$string -match '\{(.*)\}' # Several
Ndingamechese sei chiumbiridzo chimwe kana zvakawanda “< >” mu’string’ nePowershell?
$string = ''
$string -match '\<' # Only 1
$string -match "\<(.*)\>" # Several
Ndingamechese sei mavara maduku (abc) mu’string’ nePowershell
$string = 'POWERSHELLGURU'
$string -cmatch "^[a-z]*$" #False
Ndingamechese sei mavara majuru (ABC) mu’string’ nePowershell?
$string = 'powershellguru'
$string -cmatch "^[A-Z]*$" #False
Ndingameche sei “”[p” (p muduku) mustring nePowershell?
$string = '[powershellGuru]'
$string -cmatch '\[[a-z]\w+' #True
Ndingameche sei “[P” (P mukuru) mu’string’ nePowershell?
$string = '[PowershellGuru]'
$string -cmatch '\[[A-Z]\w+' #True
Ndingaisa mutsetse panga paine umwe tsetse sei nePowershell?
$a = 'Line A'
$b = 'Line B'
$a = $a -replace $a, $b
Ndingashandura sei oparesheni yekuputsa kuenda ku’string’ (mapesendi) nePowershell?
(1/2).ToString('P')
Ndingaronga sei ma’strings’ ane manhamba nePowershell?
1 |
'string-10', 'string-2', 'string-23', 'string-30' | Sort-Object -Property {$_ -replace '[\d]'}, {$_ -replace '[a-zA-Z\p{P}]'-as [int]} |
Ndingasarudza sei izwi rekupedzisira mumutsara nePowershell?
$sentence = 'My name is Test Powershell'
$sentence.Split(' ')[-1] # Returns Powershell
Ndingasarudza sei izwi hombesa mumutsara nePowershell?
$sentence = 'My name is Test Powershell'
$sentence.Split(' ') | Sort-Object -Property Length | Select-Object -Last 1 # Returns Powershell
Ndingaverega sei kuti ‘string’ iri kuwanikwa kangani mumutsara nePowershell?
$sentence = 'test test test Powershell'
[regex]::Matches($sentence, 'test').Count # Returns 3
Ndinga kopa sei vara kana saini mu’string’ ndichizvironga pamwe nePowershell?
1 2 3 4 5 6 7 |
$name = 'test' $name.ToCharArray() s t e v e |
Ndingachinja sei vara rekutanga kuti rtiite guru nePowershell?
1 2 |
$name = 'test' $name.Substring(0,1).ToUpper() + $name.Substring(1) |
Ndingachinja sei (kuruboshwe kana kuruji) nePowershell?
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 |
Ndinga kodha kana kuziva kodhi sei ye’string’ kuenda ku Base64 nePowershell?
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 |
Ndingachinja sei nhamba (kuenda kana kubva) kubhainari nePowershell?
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) |
Ndingadzosa sei forodha rekutangisisa chete muhurongwa nePowershell?
1 2 |
$path = 'C:\Folder1\Folder2\Folder3\file.txt' Split-Path -Path (Split-Path -Path $path -Parent) -Leaf # Return Folder3 |
Ndingadzosa sei chinhu chiri kwekupedzisisra muhurongwa nePowershell?
1 2 |
$path = 'C:\Folder1\Folder2\Folder3\file.txt' Split-Path -Path $path -Leaf # Return file.txt |
Math
Ndingaronga sei nzira dze ‘System.Math’ kirasi nePowershell?
[System.Math] | Get-Member -Static -MemberType Method
Ndingadzokera sei ku huzamo hwekutangisisa nePOwershell?
[Math]::Abs(-12) #Returns 12
[Math]::Abs(-12.5) # Returns 12.5
Ndingadzokera sei ku ‘angle’ yekuti ‘sine’ yacho ndiyo nhamba yakarehwa nePowershell?
[Math]::ASin(1) #Returns 1,5707963267949
Ndingadzosa sei ‘ceiling value’ nePowershell?
[Math]::Ceiling(1.4) #Returns 2
[Math]::Ceiling(1.9) #Returns 2
Ndingadzosa sei ‘floor value’ nePowershell?
[Math]::Floor(1.4) #Returns 1
[Math]::Floor(1.9) #Returns 1
Ndingadzosa sei ‘natural (base e) logarithm yenhamba nePowershell?
[Math]::Log(4) #Returns 1,38629436111989
Ndingadzosa sei ‘base 10 logarithm’ yenhamba nePowershell?
[Math]::Log10(4) #Returns 0,602059991327962
Ndingadzosa sei ‘maximum’ yemanhamba maviri nePowershell?
[Math]::Max(2,4) #Returns 4
[Math]::Max(-2,-4) #Returns -2
Ndingadzosa sei ‘minimum’ yemanhamba maviri nePowershell?
[Math]::Min(2,4) #Returns 2
[Math]::Max(-2,-4) #Returns -4
Ndingadzosa sei nhamba inenge yakapetwa zvakati nePowershell?
[Math]::Pow(2,4) #Returns 16
Ndingadzosa seyi ‘decimal value’ kuiunza kunhamba yakazara nePowershell?
[Math]::Round(3.111,2) #Returns 3,11
[Math]::Round(3.999,2) #Returns 4
Ndingadzosa sei nhamba yakazara yedecimal nhamba nePowershell?
[Math]::Truncate(3.111) #Returns 3
[Math]::Truncate(3.999) #Returns 3
Ndingadzosa sei ‘square root’ yenhamba nePowershell?
[Math]::Sqrt(16) #Returns 4
Ndingadzosa sei ‘PI constsnt’ nePowershell?
[Math]::Pi #Returns 3,14159265358979
Ndingadzosa sei ‘natural logarithmic base (constant e) nePowershell?
[Math]::E #Returns 2,71828182845905
Ndingaone sei kana nhamba iri ‘even’ kana ‘odd’ nePowershell?
[bool]($number%2)
Hashtables
Ndingagadzira sei ‘hashtable’isina zvinhu nePowershell?
$hashtable = @{}
$hashtable = New-Object -TypeName System.Collections.Hashtable
Ndingagadzira sei ‘hashtable’ ine zvinhu nePowershell?
1 2 3 4 5 |
$hashtable = @{ 'Key1' = 'Value1' 'Key2' = 'Value2' 'Key3' = 'Value3' } |
Ndingagadzira sei ‘hashtable’ ine zvinhu zvakarongeka nekuda kwekiyi kana zita nePowershell?
1 2 3 4 5 6 7 |
$hashtable = [ordered]@{ 'Key1' = 'Value1' 'Key2' = 'Value2' 'Key3' = 'Value3' } $hashtable | Get-Member # System.Collections.Specialized.OrderedDictionary |
Ndingaise sei zvimwe zvinhu (kiyi-nhamba) ku ‘hashtable’ nePowershell?
$hashtable.Add('Key3', 'Value3')
Ndingawana sei nhamba ye’hashtable’ nePowershell?
$hashtable.Key1
$hashtable.Get_Item('Key1')
Ndingawana sei nhmaba yepasi pasi ye’hashtable’ nePowershell?
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 |
Ndingawana sei nhmaba yepamusoro soro ye’hashtable’ nePowershell?
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 |
Ndingachinja sei zvinhu mu’hashtable’ nePowershell?
$hashtable.Set_Item('Key1', 'Value1Updated')
Ndingabvisa sei zvinhu mu’hashtable’ nePowershell?
$hashtable.Remove('Key1')
Ndingabvisa sei ‘hashtable’ nePowershell?
$hashtable.Clear()
Ndingaone sei kuti kiyi/nhamba yandirikuda irimu ‘hashtable’ nePowershell?
$hashtable.ContainsKey('Key3')
$hashtable.ContainsValue('Value3')
Ndingaronga sei kiyi/nhamba mu’hashtable’ nePowershell?
$hashtable.GetEnumerator() | Sort-Object -Property Name
$hashtable.GetEnumerator() | Sort-Object -Property Value -Descending
Arrays
Ndingagadzira sei ‘array’ isina chinhu nePowershell?
$array = @()
$array = [System.Collections.ArrayList]@()
Ndingagadzira sei ‘array’ ine zvinhu nePowershell?
$array = @('A', 'B', 'C')
$array = 'A', 'B', 'C'
$array = 'a,b,c'.Split(',')
$array = .{$args} a b c
$array = echo a b c
Ndingawedzera sei zvinhu mu’array’ nePowershell?
$array += 'D'
[void]$array.Add('D')
Ndingachinja sei zvinhu zviri mu’array’ nePowershell?
$array[0] = 'Z' # 1st item[0]
Ndingaona sei makuriro e’array’ nePowershell?
$array = 'A', 'B', 'C'
$array.Length # Returns 3
ndingabuditsa sei chinhu kana zvinhu zvakawanda kana zvose mu’array’ nePowershell?
$array = @('A', 'B', 'C')
$array[0] # One item (A)
$array[0] + $array[2] # Several items (A,C)
$array # All items (A,B,C)
Ndingabvisa sei zvinhu zvisina chinhu mu’array’ nePowershell?
$array = @('A', 'B', 'C', '')
$array = $array.Split('',[System.StringSplitOptions]::RemoveEmptyEntries) | Sort-Object # A,B,C
Ndingawona sei kuti chinhu chandiri kutsvaga chirimo here mu’array’ nePwershell?
$array = @('A', 'B', 'C')
'A' | ForEach-Object -Process {$array.Contains($_)} # Returns True
'D' | ForEach-Object -Process {$array.Contains($_)} # Returns False
Ndingawana sei ‘index number’ yechinhu hiri mu’array’ nePowershell?
$array = @('A', 'B', 'C')
[array]::IndexOf($array,'A') # Returns 0
Ndinga rivhesa sei marongerwo akaitwa zvinhu mu’array’ nePowershell?
$array = @('A', 'B', 'C')
[array]::Reverse($array) # C,B,A
Ndinga gadzira sei chinhu kubva muarray nePowershell?
$array | Get-Random
Ndingaronge sei ‘array’ zvichikwidza kana kudzika nePowershell?
$array = @('A', 'B', 'C')
$array | Sort-Object # A,B,C
$array | Sort-Object -Descending # C,B,A
Ndingaverenge sei huwandu hwezvinhu zviri mu’array’ nePowershell?
$array.Count
Ndingaisa sei ‘array’ pane imwe nePowershell?
$array1 = 'A', 'B', 'C'
$array2 = 'D', 'E', 'F'
$array3 = $array1 + $array2 # A,B,C,D,E,F
Ndingawana sei zvinhu zvakadzokorodzwa mu’array’ nePowershell?
$array = 'A', 'B', 'C', 'C'
($array | Group-Object | Where-Object -FilterScript {$_.Count -gt 1}).Values # Returns C
Ndingabvisa sei zvakadzokorodzwa mu’array’ nePowershell?
$array = 'A', 'B', 'C', 'C'
$array = $array | Select-Object -Unique
$array # Returns A,B,C
Ndingagadzira sei ‘array’ ine zvinhu zvinotanga na (“user01″,”user02”,… “user10”) nePowerShell?
$array = 1..10 | ForEach-Object -Process { "user$_" }
ACL
Ndingaronge sei ACL ye AD nePowershell?
(Get-Acl -Path "AD:\$dn").Access
Ndingaronge sei ACL yeforodha nePowershell?
(Get-Acl -Path C:\scripts).Access
Ndingaronge sei ma ACL permission entries (users/groups) emunhu ari kushandisa AD nePowershell?
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
Mhando dze ‘data’ dzakanyanya ndedzipi nePowershell
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 |
Ndingawana sei ‘minimum’ ne ‘maximum’ yedzimwe mhando nePowershell
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 |
Ndingaongorore sei ma ‘dtatype’ nePowershell?
1 2 3 |
32 -is [int] $true -is [bool] 'a' -is [string] |
Ndingagadzira sei ‘variable’ ye Here-string’ nePowershell?
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} "@ |
Ndingagadzira ‘variable’ nePowershell?
$powershellGuru = 'Hello'
Ndingagadzira sei ‘constant variable’ nePowershell?
Set-Variable -Name powershellGuru -Value 2015 -Option Constant
Ndingagadzira sei ‘global variable’ nePowershell?
$Global:powershellGuru = 'Hello'
Ndingaverenga sei ‘variable’ nePowershell?
$powershellGuru = 'Hello'