Если еще заявление Powershell CSV с выходным CSV - PullRequest
0 голосов
/ 07 сентября 2018

Я довольно новичок в сценариях powershell и мне нужна помощь в следующих выходных данных в формате csv. Я пытаюсь выбрать столбец, например ACCOUNT.UPLOAD и оператор make и if / else для вывода его в другой файл csv. Может кто-нибудь помочь, пожалуйста.

Sample1

Вывод csv должен выглядеть следующим образом:

Sample2

$results = Import-Csv 'C:\Users\test\Desktop\Test\customer.csv' |
Select-Object "ACCOUNT.UPLOAD"

ForEach ($row in $results) 
{
    If ($row.Type0 -ne 'CP000101', 'CP000102')
    { 
        $row."ACCOUNT.UPLOAD" = "$($row.ACCOUNT.UPLOAD)"
        Write-Host $row."ACCOUNT.UPLOAD"
    }
}   
$results | Export-Csv C:\Users\test\Desktop\Test\test.csv -NoTypeInformation

Спасибо

Ответы [ 2 ]

0 голосов
/ 07 сентября 2018

Делайте это PowerShell способом:

param(
    [Parameter(Position=0)]
    $InputFile = 'D:\\Temp\\Data.csv',
    [Parameter(Position=1)]
    $OutputFile = 'D:\\Temp\\Output.csv'
)

Import-Csv $InputFile |
    Select-Object "ACCOUNT.UPLOAD" |
    %{
        $lineno++
        if ($_.'ACCOUNT.UPLOAD' -notin @('CP000101', 'CP000102')) {
            $_ | Add-Member -Name 'ROW' -type NoteProperty -Value $lineno
            $_ # Output to pipeline
        }
    } -Begin { $lineno = 1 } |
    Export-Csv $OutputFile -NoTypeInformation

Использование:

.\Script.ps1

.\Script.ps1 inputfilename.csv outputfilefname.csv
0 голосов
/ 07 сентября 2018

Это даст вам то, что вам нужно. Добавлены комментарии, чтобы объяснить, что я сделал.

$results = Import-Csv "C:\Users\test\Desktop\Test\customer.csv" | Select-Object "ACCOUNT.UPLOAD"
# Created array to be able to add individual results from foreach
$TheCSV = @()

ForEach ($row in $results) {
    # You can use a -ne in the right hand side, if done like this.
    If (($row.'ACCOUNT.UPLOAD' -ne 'CP000101') -and $row.'ACCOUNT.UPLOAD' -ne 'CP000102') {
        # Adds the ROW column to the entry and finds the index that it was in from $results.
        # Did a +2 as it does not include the header and it starts at value 0. So to match it up with the actual excel row numbers, add 2.
        $row | Add-Member -Name 'ROW' -type NoteProperty -Value "$([array]::IndexOf($results.'ACCOUNT.UPLOAD',$row.'ACCOUNT.UPLOAD')+2)"
        $TheCSV += $row
    }
}
$TheCSV | Export-Csv "C:\Users\test\Desktop\Test\test.csv" -NoTypeInformation
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...