Вывод Powershell Select-String в виде CSV в 1 строку

Я пытаюсь получить вывод Select-String в одну строку вместо нескольких строк, но просто не могу понять то же самое.

Вот моя входная строка и чрезвычайно простой шаблон для извлечения данных после '=',

'trailer data      [REFNO=0FWEB8,STRTDATE=030119,STRTTIME=075257,STRTINTIME=671442647590,IMPIND=184,CSP_MS_SRTIME_9580=21,CSP_MS
_SRTIME_9210=24229,P4=9777A611236814D8,P7=04,CD=PT,S0=TestB82PTResponseTags,R0=00,R1=0FWEB8,CSP_MS_SRTIME_9560=24,]' | select-string -Pattern '=[A-Za-z0-9]+' -AllMatches | % { $_.Matches } | % { $_.Value.SubString(1) }

Но вместо вывода, отображаемого в отдельной строке для каждого искомого шаблона,

0FWEB8

030119

075257

671442647590

184

21

24229

9777A611236814D8

04

PT

TestB82PTResponseTags

00

0FWEB8

24

Я пытаюсь отобразить вывод в виде CSV, что означает что-то вроде этого в одной строке,

0FWEB8, 030119, 075257, 671442647590, 184, 21, 24229, 9777A611236814D8, 04, PT, TestB82PTResponseTags, 00, 0FWEB8, 24

Пытался использовать канал для Export-CSV, но даже это не удалось. Какой должен быть синтаксис? Я уверен, что это просто, но не могу понять то же самое.


person Rohit    schedule 03.03.2019    source источник


Ответы (4)


Можно написать немного проще следующим образом.

"REFNO=0FWEB8,STRTDATE=030119" | select-string -Pattern '=[A-Za-z0-9]+' -AllMatches | foreach { $_.Matches.Value.SubString(1) -join ", " }
person rokumaru    schedule 03.03.2019
comment
Спасибо, что все эти ответы на самом деле верны, как и другие участники. Я отметил вас как правильный ответ, так как смог легко расширить ваш ответ для ввода файла... - person Rohit; 03.03.2019

Здесь можно использовать -Join в зависимости от варианта использования.

about_Join | Документы Майкрософт

Итак, вы имеете в виду это...

Clear-Host
('trailer data      [REFNO=0FWEB8,STRTDATE=030119,STRTTIME=075257,STRTINTIME=671442647590,IMPIND=184,CSP_MS_SRTIME_9580=21,CSP_MS
_SRTIME_9210=24229,P4=9777A611236814D8,P7=04,CD=PT,S0=TestB82PTResponseTags,R0=00,R1=0FWEB8,CSP_MS_SRTIME_9560=24,]' | 
select-string -Pattern '=[A-Za-z0-9]+' -AllMatches | 
% { $_.Matches } | 
% { $_.Value.SubString(1) }) -join ', '

# Results
0FWEB8, 030119, 075257, 671442647590, 184, 21, 24229, 9777A611236814D8, 04, PT, TestB82PTResponseTags, 00, 0FWEB8, 24
person postanote    schedule 03.03.2019

Вы можете добавить свой результат в ArrayList, а затем использовать оператор -join, чтобы получить желаемый результат.

$values = New-Object System.Collections.ArrayList; 'trailer data      [REFNO=0FWEB8,STRTDATE=030119,STRTTIME=075257,STRTINTIME=671442647590,IMPIND=184,CSP_MS_SRTIME_9580=21,CSP_MS_SRTIME_9210=24229,P4=9777A611236814D8,P7=04,CD=PT,S0=TestB82PTResponseTags,R0=00,R1=0FWEB8,CSP_MS_SRTIME_9560=24,]' | select-string -Pattern '=[A-Za-z0-9]+' -AllMatches | % { $_.Matches } | % { $values.Add($_.Value.SubString(1)) > $null }; $values -join ","

Выход:

0FWEB8,030119,075257,671442647590,184,21,24229,9777A611236814D8,04,PT,TestB82PTResponseTags,00,0FWEB8,24
person ElasticCode    schedule 03.03.2019

Не думаю, что предлагаю что-то оригинальное, но почему бы и не попробовать?

@('trailer data      [REFNO=0FWEB8,STRTDATE=030119,STRTTIME=075257,STRTINTIME=671442647590,IMPIND=184,CSP_MS_SRTIME_9580=21,CSP_MS
_SRTIME_9210=24229,P4=9777A611236814D8,P7=04,CD=PT,S0=TestB82PTResponseTags,R0=00,R1=0FWEB8,CSP_MS_SRTIME_9560=24,]' |
Select-String -Pattern '(?<==)[^,]+' -AllMatches | Select-Object -ExpandProperty Matches | ForEach-Object Value) -join ','

or

[regex]::Matches('trailer data      [REFNO=0FWEB8,STRTDATE=030119,STRTTIME=075257,STRTINTIME=671442647590,IMPIND=184,CSP_MS_SRTIME_9580=21,CSP_MS
_SRTIME_9210=24229,P4=9777A611236814D8,P7=04,CD=PT,S0=TestB82PTResponseTags,R0=00,R1=0FWEB8,CSP_MS_SRTIME_9560=24,]', '(?<==)[^,]+').ForEach({$_.Value}) -join ','

Вывод:

0FWEB8,030119,075257,671442647590,184,21,24229,9777A611236814D8,04,PT,TestB82PTResponseTags,00,0FWEB8,24
person Andrei Odegov    schedule 03.03.2019