Не обрезать имя папки в genericList

У меня есть код, который записывает разрешения конкретного пользователя в папку со всеми подпапками в общий список. Позже в коде я распечатаю этот список. Однако, если каталог слишком большой (4+ папки), имя обрезается. Мне нужно записать полное имя каталога, а не только сокращенную версию. Есть ли какой-то параметр, который я могу использовать?

Import-Module ActiveDirectory

$User = "Testumgebung\cbruehwiler"
$UserOhneDomain = $User -creplace '^[^\\]*\\', ''
$Path = "\\ESX-SHARE\File Transfer"

$List = New-Object System.Collections.Generic.List[System.Object]
$Groups = Get-ADPrincipalGroupMembership $UserOhneDomain 
$From = $User

$GroupArrayList = New-Object System.Collections.ArrayList
foreach ($Group in $Groups)
{
$GroupArrayList.Add($Group.Name) | Out-Null 
} 

$OutputFields = @(
    @{name="Item" ;       expression={$_.Path.split(':',3)[-1]}}
    @{name="Rights" ;     expression={$Right.FileSystemRights}}
    @{name="AccessType" ; expression={$Right.AccessControlType}}
    @{name="From" ;       expression={$From}}
) 

$FileSystemObjects = Get-ChildItem $Path -Recurse | ?{ $_.PSIsContainer } | ForEach-Object {Get-Acl $_.FullName}

foreach ($Item in $FileSystemObjects) {
    foreach ($Right in $Item.Access) {
        if ($Right.IdentityReference -eq $User -And ($Right.IsInherited -eq $false))
        {
            $From = $User
            $List.Add(($Item | Select-Object $OutputFields))
        }
        foreach ($GroupArrayItem in $GroupArrayList){
            if ($Right.IdentityReference -eq ("TESTUMGEBUNG\" + $GroupArrayItem) -And ($Right.IsInherited -eq $false)) 
            {
                $From = $GroupArrayItem
                $List.Add(($Item | Select-Object $OutputFields))
            }
        }
    }   
}

$List | Out-File C:\Users\cbruehwiler\Desktop\PermissionCheck.csv
$DateTime = Get-Date
$DateTime >> C:\Users\cbruehwiler\Desktop\PermissionCheck.csv

Вот так выглядит результат.

Item                                                                   Rights                                    AccessType From             

----                                                                   ------                                    ---------- ----                                          
\\ESX-SHARE\File Transfer\TestFolder\Sub_Te...                         FullControl                                    Allow Testumgebung\cbruehwiler                      

Однако я хотел бы, чтобы это было так

\\ESX-SHARE\File Transfer\TestFolder\Sub_TestFolder\Sub_Sub_TestFolder

заранее спасибо

Похоже, часть вашего кода отсутствует...

Mathias R. Jessen 22.05.2019 15:06

Это не должно быть так важно. Я предполагаю, что это проблема синтаксиса или, может быть, проблема с powershell.

Andr0mega 22.05.2019 15:11

Это очень важно — если это то, что вы видите, когда объекты отображаются в вашей консоли, это ожидаемо — строки не «обрезаются», а подсистема форматирования в PowerShell усекает их, чтобы освободить место на экране. Если вы экспортируете данные в текстовый файл или CSV, вы, вероятно, обнаружите, что ваши строки совершенно не повреждены.

Mathias R. Jessen 22.05.2019 15:13

Опять же, как вы делаете это может быть важно, поэтому, пожалуйста, обновите свой пост с точными шагами и командами, которые вы выполняете, чтобы получить результат, который вы описываете.

Mathias R. Jessen 22.05.2019 15:17

Хорошо, спасибо. Не знал этого.

Andr0mega 22.05.2019 15:21

Да, вы определенно хотите переключиться на $List | Export-Csv PermissionCheck.csv вместо Out-File, если хотите CSV

Mathias R. Jessen 22.05.2019 15:26

Невероятно, что это решило проблему. Есть ли способ, как я могу экспортировать его в .txt?

Andr0mega 22.05.2019 15:39

Конечно, но как будет выглядеть ваш текстовый файл?

Mathias R. Jessen 22.05.2019 16:28
3 метода стилизации элементов HTML
3 метода стилизации элементов HTML
Когда дело доходит до применения какого-либо стиля к нашему HTML, существует три подхода: встроенный, внутренний и внешний. Предпочтительным обычно...
Формы c голосовым вводом в React с помощью Speechly
Формы c голосовым вводом в React с помощью Speechly
Пытались ли вы когда-нибудь заполнить веб-форму в области электронной коммерции, которая требует много кликов и выбора? Вас попросят заполнить дату,...
Стилизация и валидация html-формы без использования JavaScript (только HTML/CSS)
Стилизация и валидация html-формы без использования JavaScript (только HTML/CSS)
Будучи разработчиком веб-приложений, легко впасть в заблуждение, считая, что приложение без JavaScript не имеет права на жизнь. Нам становится удобно...
Flatpickr: простой модуль календаря для вашего приложения на React
Flatpickr: простой модуль календаря для вашего приложения на React
Если вы ищете пакет для быстрой интеграции календаря с выбором даты в ваше приложения, то библиотека Flatpickr отлично справится с этой задачей....
В чем разница между Promise и Observable?
В чем разница между Promise и Observable?
Разберитесь в этом вопросе, и вы значительно повысите уровень своей компетенции.
Что такое cURL в PHP? Встроенные функции и пример GET запроса
Что такое cURL в PHP? Встроенные функции и пример GET запроса
Клиент для URL-адресов, cURL, позволяет взаимодействовать с множеством различных серверов по множеству различных протоколов с синтаксисом URL.
0
8
21
1
Перейти к ответу Данный вопрос помечен как решенный

Ответы 1

Ответ принят как подходящий

Вы выводите в файл CSV с помощью Out-File. Это неправильно; вам нужно Export-Csv. Вы также можете убрать вывод даты в последней строке, если вам нужен юридический документ CSV. (Вы можете запустить Get-Item MyFile.csv | Format-Table Name, CreationTime, чтобы получить эту информацию позже; файловая система предоставляет вам некоторую информацию о дате бесплатно.)

Это само по себе представляет собой полное решение. Ваш вывод не будет усечен. Но я хотел бы объяснить различие, если позволите.

В Powershell есть некоторые действия по умолчанию, которые застревают в вашем фрагменте кода. Out-File принимает строковое содержимое, но вы передаете объекты, поэтому PS будет использовать средство форматирования по умолчанию. Когда первый элемент в конвейере имеет 4 или меньше видимых свойств, это будет Format-Table, иначе Format-List.

Format-Table имеет переключатель -Wrap, который приводит к тому, что переполненный контент переносится, а не обрезается. Иногда использование -AutoSize также достаточно для настройки ширины столбцов, но это поможет вам только тогда, когда проблема заключается в усечении. Format-List всегда будет заворачиваться.

Если все, что вам нужно, это одно свойство, и вы можете позволить себе потерять заголовок столбца, попробуйте подключиться к Select-Object -ExpandProperty Item.

Надеюсь, теперь стало понятно, что эти команды форматирования сводят структурированные данные в текст, хотя и в форматированный текст. Это всегда приведет к потере точности, а также затруднит дальнейшие манипуляции с данными. Если вместо этого вы используете Export-Csv, вы можете позже запустить Import-Csv, чтобы вернуть данные в виде структурированного вывода. Кроме того, вы можете открыть в Excel и т. д.

Предупреждение: Export-Csv плохо обрабатывает кавычки. Если это становится проблемой, попробуйте Export-CliXml, который использует специфичный для PS диалект XML и обеспечивает высочайшую точность, которую вы можете получить (если только вы не готовы проделать МНОГО работы!) Естественно, импортный аналог этой команды это Import-CliXml.

Последний совет для Export-Csv: часто вам не нужна информация заголовка, поэтому используйте ее с переключателем -NoTypeInformation.

Другие вопросы по теме