Как я могу преобразовать вывод prnmngr в пользовательский объект? - PullRequest
0 голосов
/ 08 мая 2018

выход cscript prnmngr.vbs -l

Server name abcd 
Printer name \\abcd.com\mailroom
Share name mailroom
Driver name Canon iR-ADV 4225/4235 UFR II
Port name mailroom.com
Comment
Location
Print processor winprint
Data type RAW
Parameters
Attributes 536
Priority 1
Default priority 0
Average pages per minute 0
Printer status Idle
Extended printer status Unknown
Detected error state Unknown
Extended detected error state Unknown

Server name cdef 
Printer name \\cdfet.com\mailroom3
Share name mailroom3
Driver name Canon iR-ADV 4225/4235 UFR II
Port name mailroomxxx.com
Comment
Location
Print processor winprint
Data type RAW
Parameters
Attributes 536
Priority 1
Default priority 0
Average pages per minute 0
Printer status Idle
Extended printer status Unknown
Detected error state Unknown
Extended detected error state Unknown

что-то вроде (обратите внимание на измененные имена выходных свойств):

$CustomPrinterobjects = New-Object –TypeName PSObject
$CustomPrinterobjects | Add-Member –MemberType NoteProperty –Name ComputerName –Value "$a" 
$CustomPrinterobjects | Add-Member –MemberType NoteProperty –Name Name –Value "$b" 
$CustomPrinterobjects | Add-Member –MemberType NoteProperty –Name ShareName –Value "$c" 
$CustomPrinterobjects | Add-Member –MemberType NoteProperty –Name DriverName –Value "$d"
$CustomPrinterobjects | Add-Member –MemberType NoteProperty –Name PortName –Value "$e"

где $a, $b, $c, $d, $e представляют значения свойств, зацикленные на выходе cscript prnmngr.vbs -l

Ответы [ 2 ]

0 голосов
/ 09 мая 2018

Вызов vbscript-скрипта из Powershell выглядит как «переписать его в Powershell» (не судить). @KoryGill задает интересный вопрос: «Почему бы просто не позвонить в Get-Printer»?

Но, к вашему вопросу, вы можете полностью превратить это в объект, но вам придется выполнить некоторые манипуляции с текстом:

$printer_stuff = $(cscript prnmngr.vbs -l)

Это создаст строковый массив с именем $printer_stuff, где у каждого элемента есть отдельная строка вывода. Вы захотите составить список токенов для каждого свойства принтера, например, имени сервера, имени принтера и т. Д. Вы будете перебирать выходные данные (в строковом массиве), копируя свойства в PSObject. Вот дешевый пример, чтобы продемонстрировать это:

## Make a list of tokens
$tokens = @('Server name', 'Printer name', 'Share name')

## This will be your printer object
$printer = New-Object -TypeName PSObject

## Parsing the string array and stuffing the good bits into your printer object
foreach ($thing in $printer_stuff[0..17]) {
    foreach ($token in $tokens) {
        if ($thing -match $token) {
            Add-Member -InputObject $printer -MemberType NoteProperty -Name $token -Value $thing.Replace($token, '')
        }
    }
}

## Here is your object...
$printer

Если сценарий prnmgr.vbs будет возвращать информацию на нескольких принтерах, вы можете поместить этот $printer объект в массив:

$printers = @()
....
$printers += $printer

Вы можете извлекать данные каждого принтера из массива строк с помощью чего-то вроде ...

$min = 0
$max = $size
while ($min -lt $printer_stuff.length) {
    $printer_stuff[$min..$max]
    $min = $max + 1
    $max += $size
}

Как видите, это большая боль в заднице, поэтому я предлагаю просто переписать это в Powershell. Если вы достаточно ловки, чтобы сделать этот бит, вы достаточно ловки, чтобы портировать vbscript-скрипт.

Удачи, A-

0 голосов
/ 09 мая 2018

Кори Джилл предлагает использовать W8 + / W2K12 + Get-Printer командлет .

Аналогично, kuujinbo предлагает Get-WmiObject -Class Win32_Printer для более ранних версий ОС.

В духе PowerShell обе команды возвращают объекты , к которым свойства можно получить прямой доступ - нет необходимости в разборе текста .


Если вам все еще нужно разобрать выходные данные из cscript prnmngr.vbs -l (если он предоставляет дополнительную информацию, которой не цитируются команды), используйте следующий подход - обратите внимание, сколько усилий требуется для разбора текстового вывод в структурированные объекты :

Учитывая, что вся информация разделена пробелами, а свойство name часть каждой строки состоит из варьирующихся номеров токенов, единственный предсказуемый способ анализа текста заключается в следующем:

  • поддерживает коллекцию известных свойств имен
  • учитывайте все, что придет после имени свойства в строке значение .

Решение PSv3 +:

# Map the input property names of interest to output property names,
# using a hashtable.
$propNameMap = @{ 
  'Server name ' = 'ComputerName'
  'Printer name ' = 'Name'
  'Share name ' = 'ShareName'
  'Driver name ' = 'DriverName'
  'Port name ' = 'PortName'
}

# Split the output of `cscript prnmngr.vbs -l` into paragraphs and 
# parse each paragaph into a custom object with only the properties of interest.
$customPrinterObjs = (cscript prnmngr.vbs -l) -join "`n" -split "`n`n" | ForEach-Object {
  $ohtFields = [ordered] @{}
  foreach ($line in $_ -split "`n") {
    foreach ($propNamePair in $propNameMap.GetEnumerator()) {
      if ($line -like ($propNamePair.Key + '*')) {
        $ohtFields[$propNamePair.Value] = $line.Substring($propNamePair.Key.length)
      }
    }
  }
  [pscustomobject] $ohtFields
}

# Output the resulting custom objects.
$customPrinterObjs

При вводе примера вышеприведенное дает 2-элементный массив [pscustomobject]:

ComputerName : abcd 
Name         : \\abcd.com\mailroom
ShareName    : mailroom
DriverName   : Canon iR-ADV 4225/4235 UFR II
PortName     : mailroom.com

ComputerName : cdef 
Name         : \\cdfet.com\mailroom3
ShareName    : mailroom3
DriverName   : Canon iR-ADV 4225/4235 UFR II
PortName     : mailroomxxx.com
  • (cscript prnmngr.vbs -l) -join "`n" собирает выходные строки из cscript prnmngr.vbs -l в массиве и затем соединяет их, чтобы сформировать одну многострочную строку.

  • -split "`n`n" разбивает полученную многострочную строку на параграфов , каждый из которых представляет свойства одного принтера.

  • Блок сценария ForEach-Object затем обрабатывает абзац свойств каждого принтера:

    • foreach($line in $_ -split "`n") разбивает многострочный абзац обратно на массив строк и зацикливает их.
    • $ohtFields = [ordered] @{} инициализирует пустую упорядоченную хеш-таблицу (где записи отражаются в порядке определения на выходе), чтобы служить основой для создания пользовательского объекта.
    • Внутренний цикл foreach затем проверяет каждую строку на наличие интересующего свойства и, если так, добавляет запись в выходную хеш-таблицу с именем выходного свойства и значением свойства, которое является частью, которая следует за скважиной. известное имя свойства в строке.
    • Наконец, упорядоченная хеш-таблица выводится как пользовательский объект путем приведения ее к [pscustomobject].
...