我们想使用 PowerShell 创建 AD 用户。使用 CSV 这不是问题,使用脚本就很容易。下一级我们希望使用 PowerShell 和 MS Access 数据库创建 AD 用户。现在我们遇到以下问题:
我们可以读取 Access 数据库,我们将其加载到一个对象中,但是当我们启动脚本时,它说它是一个对象而不是字符串。
因此,当我们将对象转换为字符串时,它会加载字符串中的所有行,并创建一个具有所有名称的用户。
PowerShell 脚本是:
$DatabaseName = "c:\temp\Nordwind.mdb"
$Query = "SELECT * FROM Users "
$ConnectionString = "Provider = Microsoft.Jet.OLEDB.4.0;Data Source=$DatabaseName"
$Connection = New-Object System.Data.OleDb.OleDbConnection $ConnectionString
$Command = New-Object System.Data.OleDb.OleDbCommand $Query, $Connection
$Connection.Open()
$Adapter = New-Object System.Data.OleDb.OleDbDataAdapter $Command
$Dataset = New-Object System.Data.DataSet
[void] $Adapter.Fill($DataSet)
$Connection.Close()
$x = Dataset.Tables
foreach ($u in $x) {
New-ADUser -Name $u.name ...
}
这是 PowerShell 中的错误:
无法将“System Object[]”转换为参数“String”所需的类型“System.String”。
我们可以用线换算
$Name = [string]u.name
New-ADUser -Name $Name ...
当我们要添加 10 个用户时,它会添加 10 个用户中的一个用户。
我们需要帮助使用 PowerShell 从 Access 数据库读取和转换单行。
数据集包含一系列表,因此当您需要迭代表中的行时,您将迭代数据集中的表(即使它只是一个表)。
改变这个:
$x = Dataset.Tables
foreach ($u in $x) {
New-ADUser -Name $u.name ...
}
进入这个:
$x = Dataset.Tables[0]
foreach ($u in $x) {
New-ADUser -Name $u.name ...
}
问题就会消失。
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)