将数据从XML提取到列表<>

时间:2015-05-25 08:40:37

标签: c# xml linq list linq-to-xml

我有这个XML文件:

<?xml version="1.0" encoding="utf-8" ?>
<Record>
  <File name="1.mot">
    <Line address="040004" data="0720" />
    <Line address="040037" data="31" />
    <Line address="04004C" data="55AA55AA" />
  </File>
  <File name="2.mot">
    <Line address="00008242" data="06" />
    <Line address="00008025" data="AFC8" />
    <Line address="00009302" data="476F6C64" />
  </File>
</Record>

我想要做的是从XML中提取信息并将其转换为列表。虽然我有点不知道从哪里开始,怎么开始。我用Google搜索了样本,问题和下面的代码就是我迄今为止构建的内容。我甚至不确定这段代码是否适合我想要发生的事情。此列表将用于程序中的某种查找。与文件1.mot类似,程序将读取1.mot,读取xml文件,解析两个文件,从xml文件中提取信息,然后执行搜索功能以验证xml中的信息是否存在于{{ 1}}。

1.mot

我的一位朋友建议使用int数组或字符串数​​组,然后使用 XElement xmlReqs = XElement.Load("XMLFile1.xml"); List<Requirement> reqs = new List<Requirement>(); foreach (var xmlReq in xmlReqs.Elements("File")) { string name = xmlReqs.Attribute("name").Value); List<InfoLine> info = new List<InfoLine>(); foreach (var xmlInfo in xmlReq.Elements("Line")) { string address = xmlProduct.Attribute("address").Value; string data = xmlProduct.Attribute("data").Value; } reqs.Add(new Requirement(address, data)); } ,但我不知道该怎么做。我对linq并不精通,但是我收集的内容似乎非常值得注意并且非常强大(?)。

无论如何,上面的代码会起作用吗?如何从列表中调用对象以用于程序的查找功能?

更新: 程序将与xml文件同时(或不同时)读取1.mot或2.mot(取决于用户首选项,这就是为什么需要指定xml中的文件名)。 1.mot文件包含:

reqs.Find(val => val[0]==target)

地址从第3个字节开始。所以,是的,将数据与这些行进行比较。

2 个答案:

答案 0 :(得分:1)

您可以使用XmlSerializer来处理XML的读取。创建一些看起来像这样的类:

public class Record
{
    [XmlElement("File")]
    public List<File> Files { get; set; }
}

public class File
{
    [XmlAttribute("name")]
    public string Name { get; set; }

    [XmlElement("Line")]
    public List<Line> Lines { get; set; } 
}

public class Line
{
    [XmlAttribute("address")]
    public int Address { get; set; }

    [XmlAttribute("data")]
    public string Data { get; set; }
}

并像这样反序列化:

var serializer = new XmlSerializer(typeof (Record));

using (var reader = XmlReader.Create("XMLFile1.xml"))            
{
    var record = (Record) serializer.Deserialize(reader);

    var first = record.Files.Single(f => f.Name == "1.mot");
    var second = record.Files.Single(f => f.Name == "2.mot");
}

答案 1 :(得分:1)

您可以反序列化xml文件

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Xml;
using System.Xml.Serialization;

namespace ConsoleApplication2
{
    class Program
    {
        const string FILENAME = @"c:\temp\test.xml";
        static void Main(string[] args)
        {
            XmlSerializer xs = new XmlSerializer(typeof(Record));
            XmlTextReader reader = new XmlTextReader(FILENAME);
            Record record = (Record)xs.Deserialize(reader);

        }
    }
    [XmlRoot("Record")]
    public class Record
    {
        [XmlElement("File")]
        public List<File> files {get;set;}
    }
    [XmlRoot("File")]
    public class File
    {
        [XmlAttribute("name")]
        public string name { get; set; }
        [XmlElement("Line")]
        public List<Line> lines {get;set;}
    }
    [XmlRoot("Line")]
    public class Line
    {
        [XmlAttribute("address")]
        public string address {get;set;}
        [XmlAttribute("data")]
        public string data {get;set;}
    }
}
​