LINQ stands for Language Integrated Query and if you use LINQ in PowerShell it might boost the performance of your scripts. In this article, I’ll show you how to use LINQ in PowerShell for comparing arrays.
In this article, I will show you except and intersect of LINQ. There are many more methods. If you are interested in other methods, check out the official documentation of Microsoft.
Table of Contents
Concept of using LINQ in PowerShell
We have three amounts red, orange and yellow. The aim is to only get a specific amount e.g. only the red portion.
data:image/s3,"s3://crabby-images/50328/50328b7a76b7032ae30c103a8df8f0e9d0a243f2" alt="How to use LINQ in PowerShell to compare arrays 3 Amounts with strings"
$Red = @( "A", "B", "C") $Yellow = @("C","D","E")
We also can do this for integer values.
data:image/s3,"s3://crabby-images/346b3/346b3236e7fc74d4520b03f8da6b2ba028db38ee" alt="How to use LINQ in PowerShell to compare arrays 4 amounts with integers"
$Red = @( 1..5) $Yellow = @(4..10)
Using LINQ for Strings in arrays
I will show you how to use LINQ for string in this chapter. We will cover the methods except and intersect.
String – Get the red amount
In order to get the red amount, you have to do following:
$Red = @( "A", "B", "C") $Yellow = @("C","D","E") $Left = [string[]]$Red $Right = [string[]]$Yellow [string[]][Linq.Enumerable]::Except($Left, $Right)
By doing this, you’ll get only A and B:
data:image/s3,"s3://crabby-images/4ff8e/4ff8e5a7304212a8fa55f5d343196338ca9d393c" alt="How to use LINQ in PowerShell to compare arrays 5 LINQ get the red amount in PowerShell"
String – Get the yellow amount
In order to get the red amount, you have to change Right and Left in the LINQ cmdlet:
$Red = @( "A", "B", "C") $Yellow = @("C","D","E") $Left = [string[]]$Red $Right = [string[]]$Yellow [string[]][Linq.Enumerable]::Except($Right, $Left)
By doing this, you’ll get only D and E:
data:image/s3,"s3://crabby-images/16aef/16aef8878fb014aa4f4043ea31772ea57dc697b5" alt="How to use LINQ in PowerShell to compare arrays 6 LINQ get the yellow amount in PowerShell"
String – Get the orange amount
If we want to get the orange amount, we have to make use of intersect
$Red = @( "A", "B", "C") $Yellow = @("C","D","E") $Left = [string[]]$Red $Right = [string[]]$Yellow [string[]][Linq.Enumerable]::Intersect($Left, $Right)
data:image/s3,"s3://crabby-images/46f2a/46f2a6f4c32a7252aaedb9060badc44b5f7d94d0" alt="How to use LINQ in PowerShell to compare arrays 7 LINQ get the orange amount in PowerShell"
String – Get everything except orange
$Red = @( "A", "B", "C") $Yellow = @("C","D","E") $Left = [string[]]$Red $Right = [string[]]$Yellow [string[]]([Linq.Enumerable]::Except($Left, $Right) + [Linq.Enumerable]::Except($Right, $Left))
By doing this, you’ll everything but not C:
data:image/s3,"s3://crabby-images/0cab2/0cab2dd7d96a1bcc17715fafec727ad366fc2674" alt="How to use LINQ in PowerShell to compare arrays 8 linq - get everything except the orange amount powershell"
Using LINQ for integers in arrays
I will show you how to use LINQ for integers in this chapter. We will cover the methods except and intersect.
Integer – Get the red amount
In order to get the red amount, you have to do following:
$Red = @( 1..5) $Yellow = @(4..10) $Left = [int[]]$Red $Right = [int[]]$Yellow [int[]][Linq.Enumerable]::Except($Left, $Right)
By doing this, you’ll get only 1, 2, 3:
data:image/s3,"s3://crabby-images/45a38/45a388e8a88b02dfae75b76bcc95f54762ceb14e" alt="How to use LINQ in PowerShell to compare arrays 9 LINQ get only the red amount in PowerShell"
Integer – Get the yellow amount
In order to get the red amount, you have to change Right and Left in the LINQ cmdlet:
$Red = @( 1..5) $Yellow = @(4..10) $Left = [int[]]$Red $Right = [int[]]$Yellow [int[]][Linq.Enumerable]::Except($Right, $Left)
By doing this, you’ll get only 6, 7, 8, 9, 10:
data:image/s3,"s3://crabby-images/07d50/07d5089498239dbe7372d8a12c3410e015ea24c7" alt="How to use LINQ in PowerShell to compare arrays 10 LINQ get the yellow amount in PowerShell for integers"
Integer – Get the orange amount
If we want to get the orange amount, we have to make use of intersect
$Red = @( 1..5) $Yellow = @(4..10) $Left = [int[]]$Red $Right = [int[]]$Yellow [int[]][Linq.Enumerable]::Intersect($Right, $Left)
data:image/s3,"s3://crabby-images/b761f/b761fadb376b3060a2e541b4f7ed891264d0040b" alt="How to use LINQ in PowerShell to compare arrays 11 LINQ get the orange amount in PowerShell for integers"
Integer – Get everything except orange
$Red = @( 1..5) $Yellow = @(4..10) $Left = [int[]]$Red $Right = [int[]]$Yellow [int[]]([Linq.Enumerable]::Except($Left, $Right) + [Linq.Enumerable]::Except($Right, $Left))
By doing this, you’ll everything but not 5:
data:image/s3,"s3://crabby-images/65ce3/65ce363aee7eb4784d24ec3e69d4472936e8589c" alt="How to use LINQ in PowerShell to compare arrays 12 LINQ get the everything but not the orange amount in PowerShell for integers"
You might be interested in getting items faster interactively. This article might help: