2015-10-21 84 views
0

我寫了一個函數和過濾器來分析CSV文件的內容。功能中指​​定的參數自動傳遞給過濾器

函數來創建列對象的管道:

function Analyze { 

     [CmdletBinding()] 
     Param(
      [String] 
      $File 
     ) 

     # get column headers from CSV; enumerate 
     $Headers = (Get-Content $File | Select-Object -First 1).Split(',') 
     $Headers | ForEach-Object { 

      # create an object that represents each column; initialize values 
      $Column = [PsCustomObject]@{'Name'=$_;'Measurements'[email protected]()} 

      # add to pipeline 
      $Column 
     } 

} 

過濾器來計算各列的內容的最小值:

filter Min { 

    Param(
     [string]$File 
    ) 

    # create Logparser query 
    $Query = "SELECT Min($($_.Name)) AS Minimum FROM '$File'" 

    # excute query; return results as XML 
    [xml] $xml = & logparser $Query -stats:off -o:xml 

    # create object to contain measurement and its value 
    $Measurement=[PsCustomObject]@{'Name'='Minimum';Value=$xml.root.row.Minimum.Trim()} 

    # add to collection and return to pipeline 
    $_.Measurements+=$Measurement 
    $_ 

} 

過濾器來計算各列的內容的最小值:

filter Max { 

    Param(
     [string]$File 
    ) 

    # create Logparser query 
    $Query = "SELECT Max($($_.Name)) AS Maximum FROM '$File'" 

    # excute query; return results as XML 
    [xml] $xml = & logparser $Query -stats:off -o:xml 

    # create object to contain measurement and its value 
    $Measurement=[PsCustomObject]@{'Name'='Maximum';Value=$xml.root.row.Maximum.Trim()} 

    # add to collection and return to pipeline 
    $_.Measurements+=$Measurement 
    $_ 

} 

用法:

pushd C:\users\<user>\Desktop 
$File = '.\d.csv' 
Analyze -File $File | Min -File $File | Max -File $File 
popd 

有沒有辦法建築師這樣的過濾器,我可以把它想:

pushd C:\users\<user>\Desktop 
Analyze -File '.\d.csv' | Min | Max 
popd 
+1

您可以通過'Analyze'函數將文件屬性添加到對象。 – PetSerAl

+0

@PetSerAl,我認爲,但它看起來像一個黑客。也許這是唯一的方法... – craig

+0

如果您希望下一個函數使用它,您必須以某種方式返回到管道。 – Matt

回答

0

基於@Mathias R.傑森的意見,我重構功能和過濾器:

function Analyze { 

    [CmdletBinding()] 
    Param(
     [Parameter(Mandatory=$True,Position=1)] 
     [alias('f')] 
     [String] 
     $File, 

     [Switch] $Min, 
     [Switch] $Max, 
     [Switch] $Top 
    ) 

    # get column headers from CSV; enumerate 
    $Included = (Get-Content $File | Select-Object -First 1).Split(',') 

    $Included | ForEach-Object { 

     # create a hash that represents each column; initialize values 
     $Column = [PsCustomObject]@{'Name'=$_;'Measurements'[email protected]()} 

     # apply specified filter; pass object via pipeline 
     if ($Min) { $Column | Min -File $File } 
     if ($Max) { $Column | Max -File $File } 
     if ($Top) { $Column | Top -File $File } 

     # add to pipeline 
     $Column 

    } 

} 

所需禁用過濾器的管道:

filter Min { 

    [Parameter(Mandatory=$True,Position=1)] 
    [alias('f')] 
    Param(
     [string]$File 
    ) 

    $Query = "SELECT Min([$($_.Name)]) AS Minimum FROM '$File'" 

    [xml] $xml = & logparser $Query -stats:off -o:xml 
    $Measurement=[PsCustomObject]@{'Name'='Minimum';Value=$xml.root.row.Minimum.Trim()} 

    $_.Measurements+=$Measurement 

    # pipeline disabled; created multiple instances of Column object 
    #$_ 

} 

# similar changes to these filters 
filter Max {} 
filter Top {} 

用法:

pushd C:\users\<user>\Desktop 
$File = '.\data.csv' 
Analyze $File -Min -Max -Top 
popd 
相關問題