首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Export-CSV仅获取"Length“

Export-CSV仅获取"Length“
EN

Stack Overflow用户
提问于 2016-09-13 12:57:03
回答 1查看 1.8K关注 0票数 0

当我尝试导出到CSV列表时,我只获得了"Length“.Count属性的所有数字,直到到达分割点,然后将CSV数组拆分到一个新文件中,该文件将使用新的名称。可能的问题是什么?

代码语言:javascript
复制
$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)
}


  }

}
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2016-09-13 14:25:17

Export-CSV被构建为接受PSCustomObjects作为输入,而不是文本行。

代码语言:javascript
复制
$thisCSV = Get-Acl $path | Select-Object -Expand Access |
    Select-Object @{n='Path';e={$path}}, IdentityReference, AccessControlType,
                  FileSystemRights |
    ConvertTo-Csv

这一行的输出类似于:

代码语言:javascript
复制
#TYPE Selected.System.Security.AccessControl.FileSystemAccessRule
"Path","IdentityReference","AccessControlType","FileSystemRights"
"c:\test","BUILTIN\Administrators","Allow","FullControl"

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

代码语言:javascript
复制
PS C:\> 'a','b' | Get-Member -MemberType Property


   TypeName: System.String

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

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

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

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

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/39462438

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档