0

以下是我的代码示例:


$logpath = @(gci -path "c:\logs")
foreach ($i in $logpath)    
        {
        [array]$n += ($i.tostring()).trimend(".log")
    [array]$t += ($i.tostring()).lastwritetime
    }
$obj = new-object psobject
$obj | Add-Member -MemberType NoteProperty -Name Logname -Value $n
$obj | Add-Member -MemberType NoteProperty -Name LastWriteTime -Value $t
$i | export-csv c:\temp\logs.csv

以下是输出的样子:

Name,LastWriteTime  
----,-------------
Value1...,Value1

以下是我希望它的样子:

Name,LastWriteTime  
Value1,Value1
Value2,Value2
4

3 回答 3

1

您可以使用 basename 属性来代替修剪文件扩展名:

gci -path "c:\logs" |
select @{l='Name';e={$_.basename}},Lastwritetime |
export-csv c:\temp\logs.csv
于 2013-10-22T14:25:10.720 回答
1

只是为了使用你的代码,你可以试试这个:

$logpath = @(gci -path "c:\logs")
$objects = @() # Empty array
foreach ($i in $logpath)    
{
  $n = ($i.tostring()).trimend(".log")
  $t = ($i.tostring()).lastwritetime

  $obj = new-object psobject
  $obj | Add-Member -MemberType NoteProperty -Name Logname -Value $n
  $obj | Add-Member -MemberType NoteProperty -Name LastWriteTime -Value $t
  $objects += $obj
}

$objects | export-csv c:\temp\logs.csv

我只是在循环内使用一组对象。

于 2013-10-22T04:45:26.313 回答
0

你太努力了。只需使用管道、select所需属性,然后将结果导出到 CSV:

$logFolders = 'C:\logs', 'D:\more\logs', 'H:\some\other\logs'
gci -Path $logFolders `
  | select @{n='Logname';e={$_.Name.TrimEnd(".log")}}, LastWriteTime `
  | Export-Csv 'C:\temp\logs.csv'
于 2013-10-22T07:48:21.280 回答