我有一个脚本,它将针对打印机列表以及列出的打印服务器的 Excel 文件运行。
我无法弄清楚的问题是如何在没有 200 行的 Excel 工作表的情况下将多台打印机添加到多台打印服务器。
我希望在 Powershell 脚本中列出打印服务器,并让foreach
命令通过动态列出的每个服务器。
这是我到目前为止的代码。我试图让$server
能够拥有服务器列表并将函数中的部分更改为列表中的下一个服务器。我附上了 .csv 格式的示例。.csv 文件格式的示例感谢任何人提供的任何帮助。
function CreatePrinter {
$server = $args[0]
$print = ([WMICLASS]"\\$server\ROOT\cimv2:Win32_Printer").createInstance()
$print.drivername = $args[1]
$print.PortName = $args[2]
$print.Shared = $false
$print.Sharename = $args[3]
$print.Location = $args[4]
$print.Comment = $args[5]
$print.DeviceID = $args[6]
$print.Put()
}
function CreatePrinterPort {
$server = $args[0]
$port = ([WMICLASS]"\\$server\ROOT\cimv2:Win32_TCPIPPrinterPort").createInstance()
$port.Name= $args[1]
$port.SNMPEnabled=$false
$port.Protocol=1
$port.HostAddress= $args[2]
$port.Put()
}
$printers = Import-Csv C:\test\NewPrinters.csv
foreach ($printer in $printers) {
CreatePrinterPort $printer.Printserver $printer.Portname $printer.IPAddress
CreatePrinter $printer.Printserver $printer.Driver $printer.Portname
$printer.Sharename $printer.Location $printer.Comment $printer.Printername
}