次の問題について、お役に立てれば幸いです。
XML データは .xml ファイルに保存されます。
XML ノードが適切な「識別名」を持っている場合 (名前で検証する場合)、いくつかの XML ノードを除外したいと思います。
以下は XML 構造です。
<Objs Version="1.1.0.1" xmlns="http://schemas.microsoft.com/powershell/2004/04">
<Obj RefId="0">
<TN RefId="0">
<T>Selected.Microsoft.ActiveDirectory.Management.ADGroup</T>
<T>System.Management.Automation.PSCustomObject</T>
<T>System.Object</T>
</TN>
<MS>
<S N="Samaccountname">user.name</S>
<S N="distinguishedname">CN=Domain Users,CN=Users,DC=company,DC=com</S>
</MS>
<Obj RefId="1">
<TNRef RefId="0" />
<MS>
<S N="Samaccountname">user.name1</S>
<S N="distinguishedname">CN=app_name_1,OU=publ,OU=app,DC=comp,DC=com</S>
</MS>
</Obj>
<Obj RefId="2">
<TNRef RefId="0" />
<MS>
<S N="Samaccountname">user.name1</S>
<S N="distinguishedname">CN=app_name_2,OU=publ,OU=app,DC=comp,DC=com</S>
</MS>
</Obj>
<Obj RefId="3">
<TNRef RefId="0" />
<MS>
<S N="Samaccountname">user.name2</S>
<S N="distinguishedname">CN=CN=app_name_3,OU=publ,OU=app,DC=comp,DC=com</S>
</MS>
</Obj>
<Obj RefId="4">
<TNRef RefId="0" />
<MS>
<S N="Samaccountname">user.name2</S>
<S N="distinguishedname">CN=app_name_4,OU=publ,OU=app,DC=comp,DC=com</S>
</MS>
</Obj>
</Objs>
内容は最初に読む
$filedata = gc $Env:HOMEDRIVE\users.xml
そして、フィルタリングして
$filedata = foreach ($obj in $filexml.Objs.Obj){
$obj.MS.S | ?{ $_.N -eq "distinguishedname"} |
%{if( $_."#text" -match "*name_1" -or $_."#text" -match "*name_4*")
{$obj}}}
私の例では、 <Obj RefId="2">
and<Obj RefId="4">
は OK であり、フィルタリングする必要があり、 and<Obj RefId="0">
は<Obj RefId="1">
XML から完全に削除する必要があります。
アドバイスをいただければ幸いです。