Преобразование тегов XML в CSV - PullRequest
0 голосов
/ 24 сентября 2019

Я хочу преобразовать некоторые теги XML в значения, разделенные запятыми (CSV)

    <variable name="Fault_Reset">
          <type>
            <BOOL />
          </type>
     </variable>
     <variable name="Cycle_On">
          <type>
            <BOOL />
          </type>
     </variable>

Я хочу, чтобы вывод выглядел следующим образом: имя переменной , тип

например,

Сброс, BOOL

Cycle_On, BOOL

Пожалуйста, помогите мне.

1 Ответ

0 голосов
/ 24 сентября 2019

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

using System.Text;
using System.Xml;
using System.Xml.Linq;

namespace ConsoleApplication132
{
    class Program
    {
        const string FILENAME = @"c:\temp\test.xml";
        static void Main(string[] args)
        {
            XDocument doc = XDocument.Load(FILENAME);

            Dictionary<string, string> dict = doc.Descendants("variable")
                .GroupBy(x => (string)x.Attribute("name"), y => (string)y.Element("type").Elements().FirstOrDefault().Name.LocalName)
                .ToDictionary(x => x.Key, y => y.FirstOrDefault());

        }
    }


}
...