繁体   English   中英

C#代码读取xml文件值

[英]c# code to read xml file values

我有这个xml文件,我想提取作者名称和访问号,而我所拥有的是C#中非常幼稚的实现,其中我正在使用xml阅读器并逐行阅读。 但是我正在寻找一种实现方式,可以在c#中有效地读取作者姓名和访问号。 我是C#的新手,有人告诉我应该使用LINQ,但是在查看文档和此文件时,我无法说明如何使用Xdocument。 任何帮助将不胜感激。

<xml>
<records>
<record>
<database name="CP_EndnoteLibrary_2012-2015-1.enl" path="C:\Users\Downloads\file.enl">file.enl</database>
<source-app name="EndNote" version="17.4">EndNote</source-app>
<rec-number>24</rec-number>
<contributors>
<authors>
<author>
<style face="normal" font="default" size="100%">ABCD, X.</style>
</author>
<author>
<style face="normal" font="default" size="100%">EFGH, I.</style>
</author> 
</authors>
</contributors>
<accession-num>
<style face="normal" font="default" size="100%">12345678</style>
</accession-num>
</record>
<record>...</record>
</records>

根据文档,我能够编写此代码来找出作者姓名。

{
    class Program
    {
        static void Main(string[] args)
        {
        XmlReader reader = XmlReader.Create("C:\\Users\\ile_xml.xml");
        while(reader.Read())
        {
            if((reader.NodeType == XmlNodeType.Element) && (reader.Name == "author"))
            {
                reader.Read();
                reader.Read();
                if((reader.NodeType == XmlNodeType.Element) && (reader.Name == "style") && reader.HasAttributes)
                {
                    var val = reader.ReadInnerXml();
                    Console.WriteLine("Display:" + reader.GetAttribute("author"));
                }
            }
        }
    }
}

}

上面的代码似乎效率很低,我正在寻找方法来改进或以更好的方式进行操作。

    //Helpfull namespaces:
using System.Xml.Linq;
using System.Xml.XPath;
using System.Xml.Serialization;

        static void Main(string[] args)
    {
        //Your snippet, which didn't work on my machine:
        XmlReader reader = XmlReader.Create("C:\\Users\\Public\\ile_xml.xml");
        while (reader.Read())
        {
            if ((reader.NodeType == XmlNodeType.Element) && (reader.Name == "author"))
            {
                reader.Read();
                reader.Read();
                if ((reader.NodeType == XmlNodeType.Element) && (reader.Name == "style") && reader.HasAttributes)
                {
                    var val = reader.ReadInnerXml();
                    Console.WriteLine("Display:" + reader.GetAttribute("author"));
                }
            }
        }
        //Should produce the results you are looking for:
        XmlNodeList xmlNodeList;
        XmlDocument xDoc = new XmlDocument();
        XmlReaderSettings xrs = new XmlReaderSettings();
        xrs.DtdProcessing = DtdProcessing.Parse;

        //Get Authors from XML Source
        using (XmlReader reader2 = XmlReader.Create("C:\\Users\\Public\\ile_xml.xml"))
        {
            xDoc.Load(reader2);
            xmlNodeList = xDoc.SelectNodes("records/record/contributors/authors/author");
        }
        foreach (XmlNode node in xmlNodeList)
        {
            Console.WriteLine(node.InnerText);//.InnerXML to include style tags.
        };
    }

xpath将帮助您找到所需的信息。 希望以上内容可以使您与xdoc更加紧密。

我最近采用的另一种模式是将xml序列化为c#类(在本例中为List),然后根据需要使用LINQ进行操作。

这对我很有帮助: 在C#中将XML反序列化为对象

这将为您提供正确的结果:

XDocument xdoc = XDocument.Load(@"YourXMLfilePath");
var result = xdoc.Root.Elements("record")
                      .Select(x => new
                                 {
                                    Name = (string)x.Element("database").Attribute("name"),
                                    Number = (string)x.Element("rec-number")
                                 });

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM