wahyzcrak
wahyzcrak

Reputation: 114

Extract text from pattern for each line in a file

I have looked over quite a bit of answers to try and hack this together, but I am having issues getting this to run with a foreach type of statement, and I can't seem to get the regex to work as a one-line - if it did the foreach I am trying to use would work, but the regex ends up returning the whole line instead of the text I need to extract.

Here is what I am using currently:

$importPath = '.\file.LOG'
$string = Get-Content $importPath
$pattern = "FROM:<(.*?)> SIZE"
$result = [regex]::match($string, $pattern).Groups[1].Value
$result

I am fairly pedestrian when it comes to powershell and am having trouble wrapping my head around how to make this return a string from every matching line in the file.

If there is a way to do this with a one liner that isn't obtuse I would prefer that method, but I am fine with doing this in a script or by assigning variables as well.

Upvotes: 1

Views: 1079

Answers (2)

mklement0
mklement0

Reputation: 437197

I suggest using a switch statement with the -file and -regex options:

$result = switch -file .\file.LOG -regex { 'FROM:<(.*?)> SIZE' { $Matches[1] } }

Upvotes: 2

Dan
Dan

Reputation: 106

Use Select-String to perfect the regex.

Select-String -Path .\file.LOG -Pattern 'FROM:<(.*?)> SIZE'

or

(Get-Content -Path .\file.LOG) -match 'FROM:<(.*?)> SIZE'

Upvotes: 0

Related Questions