Как выбрать значение XML с помощью XML Starlet

Как выбрать значение XML с помощью XML Starlet

Как получить значение с помощью xmlstarlet?

Я пытаюсь получить начальное значение 4.7 из следующего XML-файла:

<?xml version="1.0"?>
<GCContextualMethod xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:xsd="http://www.w3.org/2001/XMLSchema" xmlns="http://www.agilent.com/schemas/Analytical/Instrument/GC7890/2006/">
  <method xmlns="">
    <GC PostRunHoldTime="0" AutoPrepRun="UNKNOWN">
      <Inlet DeterminesReadiness="true">
        ...
      </Inlet>
      <Inlet DeterminesReadiness="true" />
      <Column DeterminesReadiness="true">
        ...
      </Column>
      <Column DeterminesReadiness="true">
        <Setpoints Mode="CONSTANT_FLOW">
          <Flow State="ON" InitialHoldTime="0" InitialValue="4.7" PostRunValue="4.7" />
        </Setpoints>
      </Column>
      <Column DeterminesReadiness="false">  

Я попробовал следующее, но это не сработало:

%cd%\resources\XML.EXE sel -t -c "/GCContextualMethod/method[@xmlns=""]/GC[@PostRunHoldTime="0"]/Column[2]/Setpoints[@Mode="CONSTANT_FLOW"]/Flow[@State="ON"]@InitialValue"  %cd%\GC78901.RapidControl.MethodXML.xml

решение1

В PowerShell это просто две строки:

[xml]$XmlDocument = Get-Content -Path C:\...\test.xml
$XmlDocument.GCContextualMethod.method.GC.Column.Setpoints.Flow.InitialValue | Out-File c:\temp\result.txt

Сохраните это в какой-нибудь script.ps1 и измените путь на настоящий xml. Результат 4.7 будет в файле txt.

Обратите внимание, что в реальном xml-файле все элементы типа "GCContextualMethod" или "method" должны иметь закрывающий элемент, парный открывающему. Это не представлено в вашем примере. Поэтому при создании примера я закончил xml следующим образом:

 </GC>
</method>
</GCContextualMethod>

Связанный контент