If you are working interactively with PowerShell, It might be unhandy to define all the filtering options with Where-Object. I will show you how to filter for PowerShell objects the traditional way and doing it with Out-Gridview.
Table of Contents
Filter for PowerShell objects – the traditional way with Where-Object
If we are looking forward to filter in PowerShell, we normaly make use of Where-Object this. In my example I am looking forward for all proccesses, which contain the name msedge and the value for Handles is greater than 292. My query would look like this:
#traditional way
Get-Process | Where-Object {$_.processname -contains "msedge" -and $_.Handles -gt 292}
data:image/s3,"s3://crabby-images/fbe0d/fbe0ddc9efeca0141bf998718482a68edf365573" alt="How to filter for PowerShell objects easily 3 Output of all processes in PowerShell"
Filter for PowerShell objects – Out-Gridview
I want to show you how to filter for Powershell objects easily by using following cmdlet:
Out-GridView -PassThru
Example:
Get-Process | Out-GridView -PassThru
Doing that results in a grid popping up.
data:image/s3,"s3://crabby-images/0daa9/0daa9bfb4645b0a5ca417c0327607af12fc8d800" alt="How to filter for PowerShell objects easily 4 output of processes as a grid in PowerShell"
Now you have multiple options.
You can make use of the filter of the out of the box filtering options. Let’s say I just want to find the msedge processes.
So I am adding the Processname as a filter criteria:
data:image/s3,"s3://crabby-images/ab702/ab70278abc24c8218fe431b4bbdff54ea34145ea" alt="How to filter for PowerShell objects easily 5 filtering options in the grid in PowerShell"
Adding ProcessName eligibles setting filtering following operators:
contains
does not contains
beginns with
is equal to
is not equal to
ends with
is empty
is not empty
Entering msedge to the contains field, shows only process entries, which contain msedge
data:image/s3,"s3://crabby-images/41c83/41c83a0057bdf9e749cca0798142adc20676372e" alt="How to filter for PowerShell objects easily 6 filtered results in PowerShell grid"
Now you can add additional filters.
data:image/s3,"s3://crabby-images/bf21b/bf21b90c0dd2e9da2d2bb1d7779b7f1004ff62c4" alt="How to filter for PowerShell objects easily 7 Additional filters in PowerShell"
data:image/s3,"s3://crabby-images/847ec/847ec76ced54582b5cfb1ffb3d6b54f1e32114b8" alt="How to filter for PowerShell objects easily 8 Filter for npmk equals 19"
We can even now sort all the stuff by clicking on the column, which we want to sort for.
data:image/s3,"s3://crabby-images/e6149/e6149465f1ea2a7029b3e7bed4f57a3950fdb28e" alt="How to filter for PowerShell objects easily 9 Sort for CPU in GUI"
Export objects to Excel
If you mark everything with CTRL + A, you can copy all the stuff and put it e.g. straigth to Excel
data:image/s3,"s3://crabby-images/ea883/ea883a8181a479f2140b4b4ac560d2e377f67ffb" alt="How to filter for PowerShell objects easily 10 Exporting objects to Excel"
If you want to process further with powershell, you can mark the entities needed and click on OK. I selected the first and the thridh entity.
data:image/s3,"s3://crabby-images/1ae2a/1ae2a90a1992fe7576114428b0d384d40290a531" alt="How to filter for PowerShell objects easily 11 Picture selecting only two entities"
As you see, PowerShell returns my selection
data:image/s3,"s3://crabby-images/6826c/6826c58f268aecf96ab1646bd3cf6a167220c05f" alt="How to filter for PowerShell objects easily 12 PowerShell return"
Conclusio
As you can see you can save time and coding lines, when use are working inteactively on PowerShell by filter forPowerShell objects with Out-Gridview.
You might find intersting
Filtering items with CAML. For further learnings check out the post: Filtering for SharePoint items with CAML Queries | SPO Scripts
Official documentation of Microsoft for the cmdlet Out-Gridview: Out-GridView (Microsoft.PowerShell.Utility) – PowerShell | Microsoft Docs