我有以下列表:
$list = foreach-object {$_}
output:
CN=laura monager sevilla,OU=CADIZ,OU=ANDALUCIA,OU=provincias,DC=...,DC=local
CN=andres perez rodriguez,OU=MURCIA,OU=provincias,DC=...,DC=local
CN=antonio maullet rivera,OU=MURCIA,OU=provincias,DC=...,DC=local
CN=ibai llanos galatea,OU=MURCIA,OU=provincias,DC=...,DC=local
我想选择用逗号分隔的第二个字符串,以便它显示:预期输出:
OU=CADIZ
OU=MURCIA
OU=MURCIA
OU=MURCIA
答案1
你可以split
使用逗号字符作为字符串分隔符的值,因为它是用逗号分隔的。一旦拆分字符串,该值就会变成一个数组。您可以告诉它显示拆分的每个迭代字符串的第二个元素,以使用适用的索引值(例如[1]
)获取预期值。
$List | ForEach-Object { $_.Split(",")[1] };
支持资源
-
钥匙
strSeparator
用于分割每个字符串的字符,默认为空格(空格/换行符/制表符) -
要检索元素,请指定其编号,PowerShell 会自动从 0 开始对数组元素进行编号。
例如这个数组:
PS C:\> $myArray = 64,"Hello",3.5,"World", "Demo"
将具有自动索引号:
+----+-------+-----+-------+------+ | 0 | 1 | 2 | 3 | 4 | +----+-------+-----+-------+------+ | 64 | Hello | 3.5 | World | Demo | +----+-------+-----+-------+------+
将索引号视为距起始元素的偏移量。
返回数组中的所有元素:
PS C:\> $myArray
返回数组中的第一个元素:
PS C:\> $myArray[0] 64
返回索引 #3(即第 4 个元素):
PS C:\> $myArray[3] World
返回数组中的第 2 和第 4 个索引:
PS C:\> $myArray[2,4] 3.5 Demo
返回数组中的第 4 到第 9 个索引:
PS C:\> $myArray[4..9]
答案2
\,
这些字符串是 LDAP DN,因此它比仅仅“用逗号分隔”更复杂,因为每个 DN 组件也可以在其中使用反斜杠转义。
要正确地将 DN 拆分为多个部分,请使用:
$dn = "CN=Fred Foobar\, Jr.,OU=Staff,O=Foobar Enterprises\, Inc."
$rdns = [regex]::Matches($dn, "(?:[^\\,]|\\.)+") `
| % {$_.Value} `
| % {$_ -replace "\\([^0-9A-F])", "`$1" }
# this is still not quite correct but it'll do
$cn = $rdns[0]
$ou = $rdns[1]
对于非 DN 字符串,逗号始终作为分隔符,因此更简单:
$parts = $string -split ","
$second = $parts[1]
答案3
此命令将返回列表/数组中的第一个 OU:
$list | Select-String "OU=\w+" | foreach {$_.Matches.Value}
以下是我对您两行的输出:
PS> $list | Out-String
CN=laura monager sevilla,OU=CADIZ,OU=ANDALUCIA,OU=provincias
CN=andres perez rodriguez,OU=MURCIA,OU=provincias
PS> $list | Select-String "OU=\w+" | foreach {$_.Matches.Value}
OU=CADIZ
OU=MURCIA