【问题标题】:Parse XML file for attribute from batch file从批处理文件中解析 XML 文件的属性
【发布时间】:2013-04-23 16:06:30
【问题描述】:

我正在解析如下的 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!
))

【问题讨论】:

  • +1 只是因为疯狂到尝试在批处理脚本中解析 XML。
  • -1 因为不够理智,无法实现在批处理脚本中解析 xml 是个坏主意。 (开玩笑的)
  • 看看xmlstarlet,一组命令行实用程序可以让您免于严重的不愉快。

标签: xml batch-file xml-parsing


【解决方案1】:

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

@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

【讨论】:

  • 这样逃避一切的目的是什么。另外,为什么在 Tokens 之前没有 "?
  • 您可以使用双引号来转义某些内容或用作分隔符,但不能同时使用。
【解决方案2】:

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

call xpath.bat "connection.config" "//connection/@name"
call xpath.bat "connection.config" "//connection/@value"

将其分配给变量:

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

【讨论】:

    【解决方案3】:
    @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%
    

    找到包含文字字符串“\”的数据行转义")然后将连接设置为从数据行的第七个标记开始的第五个(并且键入以进行良好测量)

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

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

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 2014-02-18
      • 1970-01-01
      • 2014-07-12
      • 2012-09-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      相关资源
      最近更新 更多