Как я могу сохранить структуру моего xml -файла в коде и получить доступ к «подтегам»? - PullRequest
0 голосов
/ 13 апреля 2020

Эй, у меня небольшая проблема, у меня xml -файл, структурированный так:

<cars>
  <car name="audi" id="123">
    <specs fuel="gas"/>
    <specs horsepower="150"/>
  </car>
  <car name="tesla" id="456">
    <specs fuel="electric"/>
    <specs horsepower="600"/>
  </car>
</cars

Я пытаюсь прочитать все данные и сохранить структуру треста из xml в код, чтобы я мог отобразить автомобиль, который я хочу позже. Поэтому я использовал ObservableCollection. Я попробовал это так:

        XElement data = XElement.Load(path);

        IEnumerable<XElement> elements = data.Elements().Elements();

        XmlData = new ObservableCollection<XElement>();

        foreach(var item in elements)
        {
            XmlData.Add(item);
        }

С помощью этого метода он не добавляет их в коллекцию. Как я могу получить разные узлы из загруженных XElements и сохранить их в ObservableCollection? Или есть гораздо более простой способ сделать это? Спасибо уже :) 1007 *

1 Ответ

2 голосов
/ 14 апреля 2020

Мне нравится помещать результаты в таблицу данных, которую вы всегда можете привязать к наблюдаемому виду. Я использовал xml linq для разбора xml

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

namespace ConsoleApplication1
{
    class Program
    {
        const string FILENAME = @"c:\temp\test.xml";
        static void Main(string[] args)
        {
            DataTable dt = new DataTable();
            dt.Columns.Add("Name", typeof(string));
            dt.Columns.Add("ID", typeof(int));
            dt.Columns.Add("Fuel", typeof(string));
            dt.Columns.Add("Horsepower", typeof(int));

            XDocument doc = XDocument.Load(FILENAME);

            foreach (XElement car in doc.Descendants("car"))
            {
                DataRow newRow = dt.Rows.Add();
                newRow["Name"] = (string)car.Attribute("name");
                newRow["ID"] = (int)car.Attribute("id");
                newRow["Fuel"] = car.Descendants("specs")
                    .Where(x => x.Attribute("fuel") != null)
                    .Select(x => (string)x.Attribute("fuel"))
                    .FirstOrDefault();
                newRow["Horsepower"] = car.Descendants("specs")
                    .Where(x => x.Attribute("horsepower") != null)
                    .Select(x => (string)x.Attribute("horsepower"))
                    .FirstOrDefault();
            }

        }
    }
}
...