5

私はXMLを初めて使用し、DelphiXETXMLDocumentを使用して次のXMLのデータにアクセスしようとしています。

<?xml version="1.0" encoding="UTF-8" ?>
<sfc:SFC xmlns:sfc="AWS_SFC">
    <ID>4294967295</ID>
    <SFC_TYPE>
        <WindSpeed>18</WindSpeed>
        <WindDir>123.6</WindDir>
        <Temperature>22.9</Temperature>
        <Pressure>1013.25</Pressure>
        <Humidity>57.9</Humidity>
        <DewPoint>16.8</DewPoint>
    </SFC_TYPE>'
    <Location>
        <longitude>18.5</longitude>
        <latitude>-34.5</latitude>
        <altitude>50.8</altitude>
    </Location>
    <StampDateTime>2012-12-17T09:30:47.0Z</StampDateTime>
</sfc:SFC>

私のコードは次のように始まります:

var
  SFC_Info: IXMLNode;
  SFC_Type: IXMLNode;
begin
  SFC_Info := XMLDocument1.DocumentElement;
  SFC_Type := SFC_Info.ChildNodes.First;
  while (SFC_Type.NodeName <> 'SFC_TYPE') do
    SFC_Type := SFC_TYPE.NextSibling;
  memDebug.Lines.Add('Wind speed = ' + SFC_Type.ChildNodes.FindNode('WindSpeed').Text);
  etc

これは私が望むことを行いますが、ループの使用は厄介なようです。'SFC_TYPE'ノードへのアクセスは次の方法で実現できると思いました

  SFC_Type := SFC_Info.ChildNodes.FindNode('SFC_TYPE');

しかし、これはnilを返します。

私は何かが足りないのですか?

4

1 に答える 1

11

ルートノードはネームスペース(AWS_SFC)を使用します。このため、XMLドキュメントの子ノードは同じ名前空間を保持する必要がありますが、これはXMLドキュメントには当てはまりません。

プロシージャに空白のNameSpaceURIパラメータを追加するだけで、ノードが見つかります。FindNode

SFC_Type := SFC_Info.ChildNodes.FindNode('SFC_TYPE', '');
于 2013-03-14T09:56:32.590 に答える