支持资源

支持资源

我有以下列表:

$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 数组

    要检索元素,请指定其编号,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

相关内容