检查特定节点使用VBScript在XML存在或不(check particular node is

2019-10-20 09:32发布

这是我的XML文件:

<ECSC>
   <ATTRIBUTES>
      <some part of attribute section>
   </ATTRIBUTES>
   <SCRIPT>
      <ETXML_LINE_TABTYPE>
         <some part of script section>                 
      </ETXML_LINE_TABTYPE>
   </SCRIPT>
   <PARAMETERS>
      <ETPAR_GUIX>
         <item>
            <PNAME>I_LANG</PNAME>
            <PTYP>I</PTYP>
            <PINDEX>0003</PINDEX>
            <PDATLEN>0128</PDATLEN>
            <PINTTYP>C</PINTTYP>
            <PINTLEN>000128</PINTLEN>
            <PDECIMALS>000000</PDECIMALS>
            <SORT_LNR>0001</SORT_LNR>
            <TAB_INDEX>0</TAB_INDEX>
         </item>
         <item>
            <PNAME>WE20_100_STEP_1</PNAME>
            <PTYP>X</PTYP>
            <PDESC>WE20 - SAPMSEDIPARTNER - 100</PDESC>
            <PINDEX>0009</PINDEX>
            <PGROUP>SAPGUI</PGROUP>
            <XMLREF_TYP>G</XMLREF_TYP>
            <PSTRUC_TYP>T</PSTRUC_TYP>
            <PREF_NAME>SAPGUI</PREF_NAME>
            <PDATLEN>0000</PDATLEN>
            <PINTLEN>000000</PINTLEN>
            <PDECIMALS>000000</PDECIMALS>
            <SORT_LNR>0001</SORT_LNR>
            <PREF_NAME2>SAPGUI</PREF_NAME2>
            <VALUE>&lt;VALUE&gt;</VALUE>
            <VAL_TYPE>T</VAL_TYPE>
            <TAB_INDEX>0</TAB_INDEX>
         </item>
         <item>
            <PNAME>V_LANG</PNAME>
            <PTYP>V</PTYP>
            <PINDEX>0007</PINDEX>
            <PGROUP>V.01</PGROUP>
            <PDATLEN>0128</PDATLEN>
            <PINTTYP>C</PINTTYP>
            <PINTLEN>000128</PINTLEN>
            <PDECIMALS>000000</PDECIMALS>
            <SORT_LNR>0002</SORT_LNR>
            <TAB_INDEX>0</TAB_INDEX>
         </item>
         <item>
            <PNAME>WE20_100_STEP_2</PNAME>
            <PTYP>X</PTYP>
            <PDESC>WE20 - SAPMSEDIPARTNER - 100</PDESC>
            <PINDEX>0010</PINDEX>
            <PGROUP>SAPGUI</PGROUP>
            <XMLREF_TYP>G</XMLREF_TYP>
            <PSTRUC_TYP>T</PSTRUC_TYP>
            <PREF_NAME>SAPGUI</PREF_NAME>
            <PDATLEN>0000</PDATLEN>
            <PINTLEN>000000</PINTLEN>
            <PDECIMALS>000000</PDECIMALS>
            <SORT_LNR>0002</SORT_LNR>
            <PREF_NAME2>SAPGUI</PREF_NAME2>
            <VALUE>&lt;VALUE&gt;</VALUE>
            <VAL_TYPE>T</VAL_TYPE>
            <TAB_INDEX>0</TAB_INDEX>
         </item>
         <item>
            <PNAME>I_AGENT</PNAME>
            <PTYP>I</PTYP>
            <PINDEX>0002</PINDEX>
            <PGROUP>I.03</PGROUP>
            <PDATLEN>0128</PDATLEN>
            <PINTTYP>C</PINTTYP>
            <PINTLEN>000128</PINTLEN>
            <PDECIMALS>000000</PDECIMALS>
            <SORT_LNR>0003</SORT_LNR>
            <TAB_INDEX>0</TAB_INDEX>
         </item>
         <item>
            <PNAME>WE20_100_STEP_3</PNAME>
            <PTYP>X</PTYP>
            <PDESC>WE20 - SAPMSEDIPARTNER - 100</PDESC>
            <PINDEX>0011</PINDEX>
            <PGROUP>GETGUI</PGROUP>
            <XMLREF_TYP>I</XMLREF_TYP>
            <PSTRUC_TYP>T</PSTRUC_TYP>
            <PREF_NAME>GETGUI</PREF_NAME>
            <PDATLEN>0000</PDATLEN>
            <PINTLEN>000000</PINTLEN>
            <PDECIMALS>000000</PDECIMALS>
            <SORT_LNR>0003</SORT_LNR>
            <PREF_NAME2>GETGUI</PREF_NAME2>
            <VALUE>&lt;VALUE&gt;</VALUE>
            <VAL_TYPE>T</VAL_TYPE>
            <TAB_INDEX>0</TAB_INDEX>
         </item>
         <item>
            <PNAME>I_TYPE</PNAME>
            <PTYP>I</PTYP>
            <PINDEX>0004</PINDEX>
            <PGROUP>V.04</PGROUP>
            <PDATLEN>0128</PDATLEN>
            <PINTTYP>C</PINTTYP>
            <PINTLEN>000128</PINTLEN>
            <PDECIMALS>000000</PDECIMALS>
            <SORT_LNR>0004</SORT_LNR>
            <TAB_INDEX>0</TAB_INDEX>
         </item>
         <item>
            <PNAME>WE20_100_STEP_4</PNAME>
            <PTYP>X</PTYP>
            <PDESC>WE20 - SAPMSEDIPARTNER - 100</PDESC>
            <PINDEX>0012</PINDEX>
            <PGROUP>GETGUI</PGROUP>
            <XMLREF_TYP>I</XMLREF_TYP>
            <PSTRUC_TYP>T</PSTRUC_TYP>
            <PREF_NAME>GETGUI</PREF_NAME>
            <PDATLEN>0000</PDATLEN>
            <PINTLEN>000000</PINTLEN>
            <PDECIMALS>000000</PDECIMALS>
            <SORT_LNR>0004</SORT_LNR>
            <PREF_NAME2>GETGUI</PREF_NAME2>
            <VALUE>&lt;VALUE&gt;</VALUE>
            <VAL_TYPE>T</VAL_TYPE>
            <TAB_INDEX>0</TAB_INDEX>
         </item>
         <item>
            <PNAME>V_AGENT</PNAME>
            <PTYP>V</PTYP>
            <PINDEX>0006</PINDEX>
            <PGROUP>I.02</PGROUP>
            <PDATLEN>0128</PDATLEN>
            <PINTTYP>C</PINTTYP>
            <PINTLEN>000128</PINTLEN>
            <PDECIMALS>000000</PDECIMALS>
            <SORT_LNR>0005</SORT_LNR>
            <TAB_INDEX>0</TAB_INDEX>
         </item>
         <item>
            <PNAME>WE20_100_STEP_5</PNAME>
            <PTYP>X</PTYP>
            <PDESC>WE20 - SAPMSEDIPARTNER - 100</PDESC>
            <PINDEX>0013</PINDEX>
            <PGROUP>GETGUI</PGROUP>
            <XMLREF_TYP>I</XMLREF_TYP>
            <PSTRUC_TYP>T</PSTRUC_TYP>
            <PREF_NAME>GETGUI</PREF_NAME>
            <PDATLEN>0000</PDATLEN>
            <PINTLEN>000000</PINTLEN>
            <PDECIMALS>000000</PDECIMALS>
            <SORT_LNR>0005</SORT_LNR>
            <PREF_NAME2>GETGUI</PREF_NAME2>
            <VALUE>&lt;VALUE&gt;</VALUE>
            <VAL_TYPE>T</VAL_TYPE>
            <TAB_INDEX>0</TAB_INDEX>
         </item>
         <item>
            <PNAME>V_TYPE</PNAME>
            <PTYP>V</PTYP>
            <PINDEX>0008</PINDEX>
            <PGROUP>V.03</PGROUP>
            <PDATLEN>0128</PDATLEN>
            <PINTTYP>C</PINTTYP>
            <PINTLEN>000128</PINTLEN>
            <PDECIMALS>000000</PDECIMALS>
            <SORT_LNR>0006</SORT_LNR>
            <TAB_INDEX>0</TAB_INDEX>
         </item>
         <item>
            <PNAME>WE20_100_STEP_6</PNAME>
            <PTYP>X</PTYP>
            <PDESC>WE20 - SAPMSEDIPARTNER - 100</PDESC>
            <PINDEX>0014</PINDEX>
            <PGROUP>SAPGUI</PGROUP>
            <XMLREF_TYP>G</XMLREF_TYP>
            <PSTRUC_TYP>T</PSTRUC_TYP>
            <PREF_NAME>SAPGUI</PREF_NAME>
            <PDATLEN>0000</PDATLEN>
            <PINTLEN>000000</PINTLEN>
            <PDECIMALS>000000</PDECIMALS>
            <SORT_LNR>0006</SORT_LNR>
            <PREF_NAME2>SAPGUI</PREF_NAME2>
            <VALUE>&lt;VALUE&gt;</VALUE>
            <VAL_TYPE>T</VAL_TYPE>
            <TAB_INDEX>0</TAB_INDEX>
         </item>
         <item>
            <PNAME>MSG_1</PNAME>
            <PTYP>X</PTYP>
            <PDESC>Rules for Message Check eCATT Command MESSAGE</PDESC>
            <PINDEX>0005</PINDEX>
            <PGROUP>MESSAGE</PGROUP>
            <XMLREF_TYP>M</XMLREF_TYP>
            <PSTRUC_TYP>T</PSTRUC_TYP>
            <PREF_NAME>ETMSG_DEF_TABTYPE</PREF_NAME>
            <PDATLEN>0000</PDATLEN>
            <PINTLEN>000000</PINTLEN>
            <PDECIMALS>000000</PDECIMALS>
            <SORT_LNR>0007</SORT_LNR>
            <PREF_NAME2>ETMSG_DEF_TABTYPE</PREF_NAME2>
            <VAL_TYPE>T</VAL_TYPE>
            <TAB_INDEX>0</TAB_INDEX>
         </item>
         <item>
            <PNAME>E_MSG_1</PNAME>
            <PTYP>X</PTYP>
            <PDESC>Collected Messages Before ENDMESSAGE</PDESC>
            <PINDEX>0001</PINDEX>
            <PGROUP>ENDMESSAGE</PGROUP>
            <XMLREF_TYP>N</XMLREF_TYP>
            <PSTRUC_TYP>T</PSTRUC_TYP>
            <PREF_NAME>ETMSG_RES_TABTYPE</PREF_NAME>
            <PDATLEN>0000</PDATLEN>
            <PINTLEN>000000</PINTLEN>
            <PDECIMALS>000000</PDECIMALS>
            <SORT_LNR>0008</SORT_LNR>
            <PREF_NAME2>ETMSG_RES_TABTYPE</PREF_NAME2>
            <VAL_TYPE>T</VAL_TYPE>
            <TAB_INDEX>0</TAB_INDEX>
         </item>
         <item>
            <PNAME>ZX_FI_FP_0569_MS07_COAS_FB_1</PNAME>
            <PTYP>X</PTYP>
            <PDESC>TF_FI_FP_FI_0569_MS07_CO_Search_Help_Internal_Orders_vTD0_1_</PDESC>
            <PINDEX>0015</PINDEX>
            <PGROUP>REF</PGROUP>
            <XMLREF_TYP>R</XMLREF_TYP>
            <PSTRUC_TYP>T</PSTRUC_TYP>
            <PREF_NAME>ZX_FI_FP_0569_MS07_COAS_FB01</PREF_NAME>
            <PDATLEN>0000</PDATLEN>
            <PINTLEN>000000</PINTLEN>
            <PDECIMALS>000000</PDECIMALS>
            <SORT_LNR>0009</SORT_LNR>
            <PREF_NAME2>ZX_FI_FP_0569_MS07_COAS_FB01</PREF_NAME2>
            <VAL_TYPE>T</VAL_TYPE>
            <TAB_INDEX>0</TAB_INDEX>
         </item>
      </ETPAR_GUIX>
   </PARAMETERS>
</ECSC>

我要检查上述XML文件中的<PARAMETER>标签节点名称<PGROUP>是存在或不..? 例如在<PARAMETER>标记为<PNAME>I_LANG</PNAME>项目没有标签或nodeName的像<PGROUP>所以在这种情况下VB脚本应显示错误。

对于<PNAME>WE20_100_STEP_1</PNAME>节点名称<PGROUP>标签是存在的,所以这是正确的这样,我想检查哪些<PNAME><PGROUP>标签是不存在的。

我曾尝试下面的VBScript:

Dim oFS      : Set oFS      = CreateObject("Scripting.FileSystemObject")
Dim sFSpec   : sFSpec       =        oFS.GetAbsolutePathName("C:\sample.xml")
Dim objMSXML : Set objMSXML = CreateObject("Msxml2.DOMDocument")
objMSXML.setProperty "SelectionLanguage", "XPath"
objMSXML.async = False
objMSXML.load sFSpec
objMSXML.validateOnParse = True  
counter=0
Set  NodeList =      objMSXML.documentElement.selectNodes("/ECSC/PARAMETERS/ETPAR_GUIX/item/PGROUP")
for each item in NodeList
myPNAME = objMSXML.getElementsByTagName("PNAME").item(counter).text
If (Left(myPNAME,1)="I") Then
    If objMSXML.getElementsByTagName("PNAME").item(counter).nodeName = "PGROUP" Then
        msgbox("PGROUP is exist for" &myPNAME)
    Else
        msgbox("PGROUP is NOT exist for" &myPNAME)
    End If
End If
counter=counter+1
  Next

请帮忙。 先感谢您。

Answer 1:

使用这个XPath,你会得到所有<PNAME>不具备相应的<PGROUGP>

/ECSC/PARAMETERS/ETPAR_GUIX/item[not(PGROUP)]/PNAME

这样,你确保每个itemNodeList必须是无<PGROUP>

Set NodeList = objMSXML.documentElement.selectNodes("/ECSC/PARAMETERS/ETPAR_GUIX/item[not(PGROUP)]/PNAME")


文章来源: check particular node is exist or not in XML using vbscript