解析XML文件的特定节点

问题描述 投票:0回答:1

我有这个XML文件(为简洁起见,被删节了:

<?xml version="1.0" encoding="utf-8" standalone="yes"?>
<feed xml:base="http://data.treasury.gov/Feed.svc/" xmlns:d="http://schemas.microsoft.com/ado/2007/08/dataservices" xmlns:m="http://schemas.microsoft.com/ado/2007/08/dataservices/metadata" xmlns="http://www.w3.org/2005/Atom">
  <title type="text">DailyTreasuryYieldCurveRateData</title>
  <id>http://data.treasury.gov/feed.svc/DailyTreasuryYieldCurveRateData</id>
  <updated>2019-11-23T23:48:22Z</updated>
  <link rel="self" title="DailyTreasuryYieldCurveRateData" href="DailyTreasuryYieldCurveRateData" />
  <entry>
    <id>http://data.treasury.gov/Feed.svc/DailyTreasuryYieldCurveRateData(7258)</id>
    <title type="text"></title>
    <updated>2019-11-23T23:48:22Z</updated>
    <author>
      <name />
    </author>
    <link rel="edit" title="DailyTreasuryYieldCurveRateDatum" href="DailyTreasuryYieldCurveRateData(7258)" />
    <category term="TreasuryDataWarehouseModel.DailyTreasuryYieldCurveRateDatum" scheme="http://schemas.microsoft.com/ado/2007/08/dataservices/scheme" />
    <content type="application/xml">
      <m:properties>
        <d:Id m:type="Edm.Int32">7258</d:Id>
        <d:NEW_DATE m:type="Edm.DateTime">2019-01-02T00:00:00</d:NEW_DATE>
        <d:BC_1MONTH m:type="Edm.Double">2.4</d:BC_1MONTH>
        <d:BC_2MONTH m:type="Edm.Double">2.4</d:BC_2MONTH>
        <d:BC_3MONTH m:type="Edm.Double">2.42</d:BC_3MONTH>
        <d:BC_6MONTH m:type="Edm.Double">2.51</d:BC_6MONTH>
        <d:BC_1YEAR m:type="Edm.Double">2.6</d:BC_1YEAR>
        <d:BC_2YEAR m:type="Edm.Double">2.5</d:BC_2YEAR>
        <d:BC_3YEAR m:type="Edm.Double">2.47</d:BC_3YEAR>
        <d:BC_5YEAR m:type="Edm.Double">2.49</d:BC_5YEAR>
        <d:BC_7YEAR m:type="Edm.Double">2.56</d:BC_7YEAR>
        <d:BC_10YEAR m:type="Edm.Double">2.66</d:BC_10YEAR>
        <d:BC_20YEAR m:type="Edm.Double">2.83</d:BC_20YEAR>
        <d:BC_30YEAR m:type="Edm.Double">2.97</d:BC_30YEAR>
        <d:BC_30YEARDISPLAY m:type="Edm.Double">2.97</d:BC_30YEARDISPLAY>
      </m:properties>
    </content>
  </entry>
  <entry>
    <id>http://data.treasury.gov/Feed.svc/DailyTreasuryYieldCurveRateData(7259)</id>
    <title type="text"></title>
    <updated>2019-11-23T23:48:22Z</updated>
    <author>
      <name />
    </author>
    <link rel="edit" title="DailyTreasuryYieldCurveRateDatum" href="DailyTreasuryYieldCurveRateData(7259)" />
    <category term="TreasuryDataWarehouseModel.DailyTreasuryYieldCurveRateDatum" scheme="http://schemas.microsoft.com/ado/2007/08/dataservices/scheme" />
    <content type="application/xml">
      <m:properties>
        <d:Id m:type="Edm.Int32">7259</d:Id>
        <d:NEW_DATE m:type="Edm.DateTime">2019-01-03T00:00:00</d:NEW_DATE>
        <d:BC_1MONTH m:type="Edm.Double">2.42</d:BC_1MONTH>
        <d:BC_2MONTH m:type="Edm.Double">2.42</d:BC_2MONTH>
        <d:BC_3MONTH m:type="Edm.Double">2.41</d:BC_3MONTH>
        <d:BC_6MONTH m:type="Edm.Double">2.47</d:BC_6MONTH>
        <d:BC_1YEAR m:type="Edm.Double">2.5</d:BC_1YEAR>
        <d:BC_2YEAR m:type="Edm.Double">2.39</d:BC_2YEAR>
        <d:BC_3YEAR m:type="Edm.Double">2.35</d:BC_3YEAR>
        <d:BC_5YEAR m:type="Edm.Double">2.37</d:BC_5YEAR>
        <d:BC_7YEAR m:type="Edm.Double">2.44</d:BC_7YEAR>
        <d:BC_10YEAR m:type="Edm.Double">2.56</d:BC_10YEAR>
        <d:BC_20YEAR m:type="Edm.Double">2.75</d:BC_20YEAR>
        <d:BC_30YEAR m:type="Edm.Double">2.92</d:BC_30YEAR>
        <d:BC_30YEARDISPLAY m:type="Edm.Double">2.92</d:BC_30YEARDISPLAY>
      </m:properties>
    </content>
  </entry>
  <entry>
    <id>http://data.treasury.gov/Feed.svc/DailyTreasuryYieldCurveRateData(7260)</id>
    <title type="text"></title>
    <updated>2019-11-23T23:48:22Z</updated>
    <author>
      <name />
    </author>
    <link rel="edit" title="DailyTreasuryYieldCurveRateDatum" href="DailyTreasuryYieldCurveRateData(7260)" />
    <category term="TreasuryDataWarehouseModel.DailyTreasuryYieldCurveRateDatum" scheme="http://schemas.microsoft.com/ado/2007/08/dataservices/scheme" />
    <content type="application/xml">
      <m:properties>
        <d:Id m:type="Edm.Int32">7260</d:Id>
        <d:NEW_DATE m:type="Edm.DateTime">2019-01-04T00:00:00</d:NEW_DATE>
        <d:BC_1MONTH m:type="Edm.Double">2.4</d:BC_1MONTH>
        <d:BC_2MONTH m:type="Edm.Double">2.42</d:BC_2MONTH>
        <d:BC_3MONTH m:type="Edm.Double">2.42</d:BC_3MONTH>
        <d:BC_6MONTH m:type="Edm.Double">2.51</d:BC_6MONTH>
        <d:BC_1YEAR m:type="Edm.Double">2.57</d:BC_1YEAR>
        <d:BC_2YEAR m:type="Edm.Double">2.5</d:BC_2YEAR>
        <d:BC_3YEAR m:type="Edm.Double">2.47</d:BC_3YEAR>
        <d:BC_5YEAR m:type="Edm.Double">2.49</d:BC_5YEAR>
        <d:BC_7YEAR m:type="Edm.Double">2.56</d:BC_7YEAR>
        <d:BC_10YEAR m:type="Edm.Double">2.67</d:BC_10YEAR>
        <d:BC_20YEAR m:type="Edm.Double">2.83</d:BC_20YEAR>
        <d:BC_30YEAR m:type="Edm.Double">2.98</d:BC_30YEAR>
        <d:BC_30YEARDISPLAY m:type="Edm.Double">2.98</d:BC_30YEARDISPLAY>
      </m:properties>
    </content>
  </entry>
  <entry>
    <id>http://data.treasury.gov/Feed.svc/DailyTreasuryYieldCurveRateData(7261)</id>
    <title type="text"></title>
    <updated>2019-11-23T23:48:22Z</updated>
    <author>
      <name />
    </author>
    <link rel="edit" title="DailyTreasuryYieldCurveRateDatum" href="DailyTreasuryYieldCurveRateData(7261)" />
    <category term="TreasuryDataWarehouseModel.DailyTreasuryYieldCurveRateDatum" scheme="http://schemas.microsoft.com/ado/2007/08/dataservices/scheme" />
    <content type="application/xml">
      <m:properties>
        <d:Id m:type="Edm.Int32">7261</d:Id>
        <d:NEW_DATE m:type="Edm.DateTime">2019-01-07T00:00:00</d:NEW_DATE>
        <d:BC_1MONTH m:type="Edm.Double">2.42</d:BC_1MONTH>
        <d:BC_2MONTH m:type="Edm.Double">2.42</d:BC_2MONTH>
        <d:BC_3MONTH m:type="Edm.Double">2.45</d:BC_3MONTH>
        <d:BC_6MONTH m:type="Edm.Double">2.54</d:BC_6MONTH>
        <d:BC_1YEAR m:type="Edm.Double">2.58</d:BC_1YEAR>
        <d:BC_2YEAR m:type="Edm.Double">2.53</d:BC_2YEAR>
        <d:BC_3YEAR m:type="Edm.Double">2.51</d:BC_3YEAR>
        <d:BC_5YEAR m:type="Edm.Double">2.53</d:BC_5YEAR>
        <d:BC_7YEAR m:type="Edm.Double">2.6</d:BC_7YEAR>
        <d:BC_10YEAR m:type="Edm.Double">2.7</d:BC_10YEAR>
        <d:BC_20YEAR m:type="Edm.Double">2.86</d:BC_20YEAR>
        <d:BC_30YEAR m:type="Edm.Double">2.99</d:BC_30YEAR>
        <d:BC_30YEARDISPLAY m:type="Edm.Double">2.99</d:BC_30YEARDISPLAY>
      </m:properties>
    </content>
  </entry>
  ...

我需要获取NEW_DATEBC_x_YEAR数据。我编写了该程序,使我到达了m:properties部分的位置,但是我不知道如何提取此部分中的值?

using System;
using System.Xml;

class Program
{
    static void Main()
    {
        // Create an XML reader for this file.
        using (XmlReader reader = XmlReader.Create(@"C:\Users\idf\Downloads\IRs\2019.xml"))
        {
            while (reader.Read())
            {
                // Only detect start elements.
                if (reader.IsStartElement())
                {
                    // Get element name and switch on it.
                    switch (reader.Name)
                    {
                        case "m:properties":
                            // Detect this element.
                            Console.WriteLine("Start <m:properties> element."); 
                            break;
                        default:
                            Console.WriteLine(reader.Name);
                            break;
                    }
                }
            }
        }
    }
}
c# xml-parsing
1个回答
0
投票

您可以为此目的使用Linq到Xml。对于示例,

var xDoc = XDocument.Parse(xml);
XNamespace rootNs = xDoc.Root.GetDefaultNamespace();
XNamespace dataServiceNs = "http://schemas.microsoft.com/ado/2007/08/dataservices";
var keysToSearch = new []{"NEW_DATE","BC_1YEAR","BC_2YEAR","BC_3YEAR","BC_5YEAR","BC_7YEAR","BC_10YEAR","BC_20YEAR","BC_30YEAR"};
foreach(var entry in xDoc.Descendants(rootNs+"entry"))
{
    Console.WriteLine($"Entry Id: {entry.Element(rootNs+"id").Value}");
    foreach(var key in keysToSearch)
    {
        Console.WriteLine($"{key}:{entry.Descendants(dataServiceNs + key).First().Value}");
    }
}

如果您不想基于entry将它们分组,那么您甚至可以这样做

foreach(var key in keysToSearch)
{
    foreach(var item in xDoc.Descendants(dataServiceNs + key))
    {
        Console.WriteLine($"{key}:{item.Value}");
    }
}
© www.soinside.com 2019 - 2024. All rights reserved.