XML节点的读取值

本文关键字:读取 节点 XML | 更新日期: 2023-09-27 17:50:21

我需要在XML文件中获取节点的值。

我的XML文件看起来像这样:

<?xml version="1.0" encoding="UTF-8"?>
<PRODUCTS>
<IPHONE>
    <NAME>iPhone 5s</NAME>
    <MODEL>5s</MODEL>
    <PRICE>899</PRICE>
    <COLOR>Gold</COLOR>
</IPHONE>

我想从文件中获取文本(iPhone 5s)。我尝试了一些我在网上找到的东西:

protected void Page_Load(object sender, EventArgs e)
{
    String[][] products = new String[3][];
    int i = 0;
    int j = 0;
    System.Xml.XmlTextReader reader = new System.Xml.XmlTextReader("../XML-Test/Webshop-products.xml");
    while (reader.Read()) {
        if (reader.NodeType == XmlNodeType.Element)
        {
            if (reader.LocalName.Equals("NAME"))
            {
                //Name of product
                products[i][j] = reader.ReadInnerXml();
                j++;
            }
            if (reader.LocalName.Equals("MODEL"))
            {
                //Model
                products[i][j] = reader.ReadString();
                j++;
            }
            if (reader.LocalName.Equals("PRICE"))
            {
                //Price
                products[i][j] = reader.Value;
                j++;
            }
            if (reader.LocalName.Equals("COLOR"))
            {
                //Color
                products[i][j] = reader.Value;
                j++;
                i++;
            }
        }
    }
    for (int k = 0; k < products.Length; k++)
    {
        for (int l = 0; l < products[k].Length; l++)
        {
            Console.Write(products[k][l]);
        }
    }
}

似乎没有办法工作。当我运行项目(ASP。. NET项目)我得到以下错误:

系统。NullReferenceException:对象引用未设置为对象的实例

如何获取节点的值?

XML节点的读取值

您可以使用Linq To Xml

假设PRODUCTS下有其他产物如IPHONE

var products = XDocument.Load(filename).Root
                .Elements()
                .Select(x => new
                {
                    Product = x.Name.LocalName,
                    Name = (string)x.Element("NAME"),
                    Model = (string)x.Element("MODEL"),
                    Price = (decimal)x.Element("PRICE"),
                    Color = (string)x.Element("COLOR")
                })
                .ToList();

我建议使用Linq to Xml:

var xdoc = XDocument.Load("../XML-Test/Webshop-products.xml");
var p = xdoc.Root.Element("IPHONE"); // get first IPHONE from file
if (iPhoneElement == null)
   return; // handle case when there is no IPHONE in xml file
var iPhone = new { 
      Name = (string)p.Element("NAME"),
      Model = (string)p.Element("MODEL"),
      Price = (decimal)p.Element("PRICE"),
      Color = (string)p.Element("COLOR")          
};

则可以使用iPhone对象的名称、型号、价格或颜色。例如

iPhone.Name

注意-如果文件中有很多iphone,你可以全部抓取:

var iPhones = from p in xdoc.Root.Elements("IPHONE")
              select new {
                  Name = (string)p.Element("NAME"),
                  Model = (string)p.Element("MODEL"),
                  Price = (decimal)p.Element("PRICE"),
                  Color = (string)p.Element("COLOR") 
              };

您可能还想看看下面给出的方法。

1) XmlDocument和XmlNode

2)序列化和反序列化。

3)序列化和反序列化的简化示例