簡體   English   中英

使用C#從文件中讀取XML文件

[英]Read XML file from a file using C#

我有一個具有此結構的xml文件。 節點“設置”僅重復一次。 節點“提醒”可以出現+ 1次。

<?xml version="1.0" encoding="utf-8"?>
<!--Name App-->
<AllSettings>
  <Settings>
    <tax1>21</tax1>
    <tax2>0</tax2>    
  </Settings>
  <Reminders>
    <Name>s8</Name>
    <Title>xxxxx</Title>
    <Content>xxxxxxxxx</Content>
    <BeginTime>09/11/2012 10:00:00</BeginTime>
  </Reminders>
  <Reminders>
    <Name>s2</Name>
    <Title>zzzzzzzzz</Title>
    <Content>zzzzzzzzzzz</Content>
    <BeginTime>07/11/2012 13:00:00</BeginTime>    
  </Reminders>  
</AllSettings>

我可以使用底部代碼在“settings”節點中讀取數據。 但是我怎樣才能從每個節點“提醒”中讀取數據?

IsolatedStorageFileStream isoFileStream = myIsolatedStorage.OpenFile(myXmlFile, FileMode.Open);
isoFileStream.Position = 0;
XmlReader xmlReader;
xmlReader = XmlReader.Create(isoFileStream);                                           
xmlReader.MoveToContent(); 

while (xmlReader.Read())
{    

  if (xmlReader.NodeType == XmlNodeType.Element && xmlReader.LocalName == "Settings"
  {
     while (xmlReader.NodeType != XmlNodeType.EndElement)
     {
          xmlReader.Read();

          if (xmlReader.Name == "tax1")
          {
                _tax1 = xmlReader.ReadElementContentAsString();
          }
          else if (xmlReader.Name == "tax2")
          {
                _tax2 = xmlReader.ReadElementContentAsString();
          }

      } // end while
  } 
  else if (xmlReader.NodeType == XmlNodeType.Element && xmlReader.LocalName == "Reminders")
  {
       // ????            
  }

} // end while

使用Linq2Xml要容易得多

var xDoc = XDocument.Load(filename);
var reminders = xDoc.Descendants("Reminders")
                    .Select(r => new
                    {
                        Name = (string)r.Element("Name"),
                        Title = (string)r.Element("Title"),
                        Content = (string)r.Element("Content"),
                        BeginTime = (DateTime)r.Element("BeginTime"),
                    })
                    .ToList();

var firstTitle = reminders[0].Title;

要么

var remDicts = xDoc.Descendants("Reminders")
       .Select(r => r.Elements().ToDictionary(e => e.Name.LocalName, e => e.Value))
       .ToList();

var firstTitle = remDicts[0]["Title"];

將其加載到XDocument並使用LINQ to XML進行查詢。

var isoFileStream = myIsolatedStorage.OpenFile(myXmlFile, FileMode.Open);
isoFileStream.Position = 0;

var xdoc = XDocument.Load(isoFileStream);
var reminderNodes = from n in xdoc.Descendants("Reminders") select n;

foreach (var n in reminderNodes)
{
    ProcessReminder(n);
}

void ProcessReminder(XElement node)
{
    // do something... for now I'll just output to console.
    Console.WriteLine("Name: {0}", n.Element("Name").Value); 
    Console.WriteLine("Title: {0}", n.Element("Title").Value);
    Console.WriteLine("BeginTime: {0}", n.Element("BeginTime").Value);
    Console.WriteLine();
}

我建議使用XmlNode.Value而不是從XmlReader獲取數據。

我建議使用xsd.exe工具從XM生成.XSD,從.XSD生成C#類,之后,只需使用LINQ語法進行查詢。

這可能有助於搜索

您可以使用XmlDocument而不是XmlReader

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM