从批处理文件中解析属性的XML文件

时间:2013-04-23 16:06:30

标签: xml batch-file xml-parsing

我正在解析如下的XML文件:

<?xml version="1.0"?>
<!--
-->
<configuration>
   <settings>
      <connections>
            <connection name="name1" value="connection1" type="abc"/>
            <connection name="name2" value="connection2" type="def"/>
      </connections>
   </settings>
</configuration>

从批处理文件中,我提示用户输入连接名称。我想解析XML获取具有指定名称的连接并获取其值。所以如果用户给出name1,我想选择connection1。我从Extract XML Tag Values (Based on a Flag) Using Batch

获得了以下代码

我不熟悉for循环(特别是分隔符,令牌)批处理文件,所以我不确定这是如何工作的以及如何让它对我有效。

(for /F "tokens=1,2 delims== " %%a in (connection.config) do (
   if "%%~b" neq "" set %%a=%%~b
   if /I "!name!" equ "%name%" echo !value!
))

3 个答案:

答案 0 :(得分:4)

如果您使用正确的令牌和分隔符,它会起作用:

@echo off&setlocal
for /F tokens^=2^,3^,5delims^=^<^"^= %%a in (connection.config) do (
   if "%%a" equ "connection name" echo(%%b %%c
)

输出是:

name1 connection1
name2 connection2

答案 1 :(得分:2)

@ECHO OFF
SETLOCAL
SET "name=name1"
SET "connection="
SET "type="

for /F "tokens=5,7delims==/ " %%a in (
 'findstr /c:"<connection name=\"%name%\"" ^<connection.config'
 ) do SET connection=%%~a&SET type=%%~b

ECHO connection=%connection%
ECHO TYPE      =%type%

查找包含文字字符串“\”的数据行转义")然后从数据行的第七个标记设置连接到第5个(并输入正确的度量)

        <connection name="name1" value="connection1" type="abc"/>

使用=/[space]作为分隔符。

答案 2 :(得分:1)

这里是xpath.bat -small脚本,它允许您通过xpath表达式获取xml值,而无需使用外部二进制文件:

for /f "tokens=* delims=" %%# in ('xpath.bat "connection.config" "//connection/@value"') do set "connection_value=%%#"
echo %connection_value%

将此值分配给变量:

   <httpCompression directory="">
    <scheme name="gzip" dll=""/>
    <dynamicTypes>
      <add mimeType="*/*" enabled="true"/>
    </dynamicTypes>
    <staticTypes>
      <add mimeType="*/*" enabled="true"/>
    </staticTypes>
  </httpCompression>