Export-CSV 仅获取 "Length"
Export-CSV only gets the "Length"
当我尝试导出到 CSV 列表时,我只得到 "Length" 的所有数字
.Count
属性 直到到达分割点,然后将 CSV 数组分割成一个新文件,并使用新名称从这一点开始使用。可能是什么问题?
$RootFolder = Get-Content "c:\DRIVERS\myfile.txt"
foreach ($arrayOfPaths in $RootFolder){
$csv = $arrayofPaths -replace '^\\[^\]+\([^\]+)\([^\]+).*', 'C:\output\Company_name__.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__.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)
}
}
}
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+ 行文本)。
当我尝试导出到 CSV 列表时,我只得到 "Length" 的所有数字
.Count
属性 直到到达分割点,然后将 CSV 数组分割成一个新文件,并使用新名称从这一点开始使用。可能是什么问题?
$RootFolder = Get-Content "c:\DRIVERS\myfile.txt"
foreach ($arrayOfPaths in $RootFolder){
$csv = $arrayofPaths -replace '^\\[^\]+\([^\]+)\([^\]+).*', 'C:\output\Company_name__.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__.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)
}
}
}
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+ 行文本)。