Преобразование тегов XML в CSV
Я хочу преобразовать некоторые теги XML в значения, разделенные запятыми (CSV)
<variable name="Fault_Reset">
<type>
<BOOL />
</type>
</variable>
<variable name="Cycle_On">
<type>
<BOOL />
</type>
</variable>
Я хочу, чтобы результат выглядел так:имя переменной,тип
например
Fault_Reset,BOOL
Cycle_On,BOOL
Пожалуйста, помогите мне.
1 ответ
Решение
Как использование словарей для этого типа кода. Я думаю, что BOOL должен быть внутренним текстом вместо имени тега. Попробуйте код ниже, который работает с опубликованным 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());
}
}
}