【问题标题】:Export-CSV only gets the "Length"Export-CSV 仅获取“长度”
【发布时间】:2017-01-20 14:34:02
【问题描述】:

当我尝试导出到 CSV 列表时,我只得到“长度”的所有数字 .Count 属性,直到到达拆分点,然后将 CSV 数组拆分为具有新名称的新文件,该文件将从该点开始使用。可能是什么问题?

$RootFolder = Get-Content "c:\DRIVERS\myfile.txt"

foreach ($arrayOfPaths in $RootFolder){

  $csv  = $arrayofPaths -replace '^\\\\[^\\]+\\([^\\]+)\\([^\\]+).*', 'C:\output\Company_name_${1}_${2}.csv'
  $csvIndex = 1
  $maxRows = 1000000
  $rowsLeft = $maxRows

  Get-ChildItem $arrayOfPaths -Recurse | Where-Object {$_.mode -match "d"} | ForEach-Object {
  #$csv  = $_.FullName -replace '^\\\\[^\\]+\\([^\\]+)\\([^\\]+).*', 'C:\output\Company_name_${1}_${2}.csv'# <- construct CSV path here
  $path = $_.FullName
  $thisCSV = Get-Acl $path | Select-Object -Expand Access |
    Select-Object @{n='Path';e={$path}}, IdentityReference, AccessControlType,
                  FileSystemRights |
    ConvertTo-Csv
if ($thisCSV.count -lt $rowsLeft) {
    $thisCSV | Export-Csv $csv -append -noType
    $rowsLeft -= $thisCSV.count
} else {
    $thisCSV[0..($rowsLeft - 1)] | Export-Csv $csv -append -noType
    $csvIndex++
    $csv = $csv -replace '\.csv$', "$csvIndex.csv"
    if ($thisCSV.count -gt $rowsLeft) {
        $thisCSV[$rowsLeft..($thisCSV.count - 1)] | Export-Csv $csv -append -noType
    }
    $rowsLeft = $maxRows - ($thisCSV.count - $rowsLeft)
}


  }

}

【问题讨论】:

  • 考虑创建一个MCVE 并提供演示问题的示例输入。到目前为止,代码墙假定从文件中读取内容。它做了很多可能与实际问题无关的事情。

标签: excel powershell split export-to-csv


【解决方案1】:

Export-CSV 将 PSCustomObjects 作为输入,而不是文本行。

$thisCSV = Get-Acl $path | Select-Object -Expand Access |
    Select-Object @{n='Path';e={$path}}, IdentityReference, AccessControlType,
                  FileSystemRights |
    ConvertTo-Csv

这一行的输出将类似于:

#TYPE Selected.System.Security.AccessControl.FileSystemAccessRule
"Path","IdentityReference","AccessControlType","FileSystemRights"
"c:\test","BUILTIN\Administrators","Allow","FullControl"

至少三行,一个字符串数组。字符串数组有什么属性?

PS C:\> 'a','b' | Get-Member -MemberType Property


   TypeName: System.String

Name   MemberType Definition       
----   ---------- ----------       
Length Property   int Length {get;}

长度。您在 CSV 中看到的唯一属性,因为 Export-CSV 正在导出所有属性,这是唯一的属性。

修复:从 Get-ACL 行中删除 | ConvertTo-CSV,将您的自定义对象保留为自定义对象,并让导出处理转换它们。

(这也应该解决计数问题,因为每次尝试导出 1+ 行数据时它不计算 3+ 行文本)。

【讨论】:

    猜你喜欢
    • 2019-07-18
    • 1970-01-01
    • 2013-10-27
    • 1970-01-01
    • 2017-12-15
    • 2016-12-25
    • 2021-02-05
    • 1970-01-01
    • 2021-06-18
    相关资源
    最近更新 更多