簡體   English   中英

CSV Output 不可讀

[英]CSV Output Unreadable

我正在嘗試將這個簡單腳本的結果導出到 a.csv 文件。 我得到了結果,但它要么返回有關結果數據的信息,要么返回一長串混亂的數據,我確定如何正確解析。

<# 
Will ping all devices in list and display results as a simple UP or DOWN, color coded Red or Green.
#>


$Names = Get-Content -Path "C:\TestFolder\GetNames.txt"

$Output = @() 

foreach ($name in $names)
{

    if (Test-Connection -ComputerName $name -Count 1 -ErrorAction SilentlyContinue)
        {
            $Result1 += "$name, up" 
            Write-Host "$name, up" -ForegroundColor Green
           
        }

    else
        
        {
          $Result2 += "$name, down" 
          Write-Host "$name, down" -ForegroundColor Red

        }
    }

$Output += $Result1, $Result2
$Output = $Output | Select-Object 

$Output | Export-Csv -Path 'C:\psCSVFiles\mycsv.csv' -NoTypeInformation

本次返回結果:長度 49768 25081

我在這里做錯了什么? 謝謝

不要嘗試手動“格式化” output 字符串 - Export-Csv會處理該部分。

您要做的是創建具有與您想要在 CSV 中的列相對應的屬性的對象

$Names = Get-Content -Path "C:\TestFolder\GetNames.txt"

$Output = foreach ($name in $names) {
  # test if computer is reachable/pingable
  $isUp = Test-Connection -ComputerName $name -Count 1 -ErrorAction SilentlyContinue -Quiet

  # construct output object with results
  [pscustomobject]@{
    ComputerName = $name
    Status = if($isUp){ 'Up' }else{ 'Down' }
  }
}

# Export to CSV
$Output |Export-Csv -Path 'C:\psCSVFiles\mycsv.csv' -NoTypeInformation

或者,使用Select-Object直接使用管道修改輸入字符串:

Get-Content -Path "C:\TestFolder\GetNames.txt" |Select @{Name='ComputerName';Expression={$_}},@{Name='Status';Expression={if(Test-Connection -ComputerName $_ -Count 1 -ErrorAction SilentlyContinue -Quiet){'Up'}else{'Down'}}} |Export-Csv -Path 'C:\psCSVFiles\mycsv.csv' -NoTypeInformation

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM