Warning: file_get_contents(/data/phpspider/zhask/data//catemap/0/xml/12.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
C# 从XML转换为CSV_C#_Xml_Csv - Fatal编程技术网

C# 从XML转换为CSV

C# 从XML转换为CSV,c#,xml,csv,C#,Xml,Csv,我一直在寻找将XML转换为CSV的解决方案,但由于XML结构不同,我找不到与我的案例相匹配的解决方案 XML结构看起来像 <VWSRecipeFile> <EX_Extrusion User="ABC" Version="1.0" Description="" LastChange="41914.7876341204"> <Values> <C22O01_A_TempFZ1_Set Item="A_Temp

我一直在寻找将XML转换为CSV的解决方案,但由于XML结构不同,我找不到与我的案例相匹配的解决方案

XML结构看起来像

<VWSRecipeFile>
    <EX_Extrusion User="ABC" Version="1.0" Description="" LastChange="41914.7876341204">
        <Values>
            <C22O01_A_TempFZ1_Set Item="A_TempFZ1_Set" Type="4" Hex="42700000" Value="60"/>
            <C13O02_A_TempHZ2_Set Item="A_TempHZ2_Set" Type="4" Hex="43430000" Value="195"/>
            <C13O03_A_TempHZ3_Set Item="A_TempHZ3_Set" Type="4" Hex="43430000" Value="195"/>
        </Values>
    </EX_Extrusion>
</VWSRecipeFile>
预期的CSV格式

A_TempFZ1_集、A_TempHZ2_集、A_TempHZ3_集

60195195

我可以实现新的预期csv格式,但不知道这是否是最好的方式,任何建议都是感激的

"


感谢

基本思想是为每个节点创建和选择所需的属性,并使用逗号分隔符将它们写入文件中。只需将文件命名为.csv即可。如果您想要现成的东西,请查看。

一种方法是使用XSLT,这是一种设计用于XML的语言。您当然可以用C解析XML,但我喜欢XSLT,因为它更干净

定义一个外部XSLT文件,然后在C中调用它来进行转换

编辑:根据新需求添加新列

文件C:\xmltosv.xslt&xA;是换行符吗

<?xml version="1.0" encoding="utf-8"?>
<xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
    <xsl:output method="text" indent="no"/>

    <xsl:template match="/VWSRecipeFile">
      <xsl:variable name="User" select="EX_Extrusion/@User"/>
      <xsl:variable name="Version" select="EX_Extrusion/@Version"/>
      <xsl:variable name="Description" select="EX_Extrusion/@Description"/>
      <xsl:variable name="LastChange" select="EX_Extrusion/@LastChange"/>

      <xsl:text>Item,Type,Hex,Value,User,Version,Description,LastChange&#xA;</xsl:text>
      <xsl:for-each select="EX_Extrusion/Values/*">
        <xsl:value-of select="concat(@Item,',',@Type,',',@Hex,',',@Value,',',$User,',',$Version,',',$Description,',',$LastChange,'&#xA;')"/>
      </xsl:for-each>
    </xsl:template>
</xsl:stylesheet>

根据您的需要进行调整。

XSLT是一种方法。或者,您可以使用,-一个可用于解析xml的开放源代码库,以您想要的方式生成CSV

string xml = @"<VWSRecipeFile>
    <EX_Extrusion User=""ABC"" Version=""1.0"" Description="""" LastChange=""41914.7876341204"">
        <Values>
            <C22O01_A_TempFZ1_Set Item=""A_TempFZ1_Set"" Type=""4"" Hex=""42700000"" Value=""60""/>
            <C13O02_A_TempHZ2_Set Item=""A_TempHZ2_Set"" Type=""4"" Hex=""43430000"" Value=""195""/>
            <C13O03_A_TempHZ3_Set Item=""A_TempHZ3_Set"" Type=""4"" Hex=""43430000"" Value=""196""/>
        </Values>
    </EX_Extrusion>
</VWSRecipeFile>";

StringBuilder sb = new StringBuilder();
using (var p = ChoXmlReader.LoadText(xml).WithXPath("/Values/*"))
{
    using (var w = new ChoCSVWriter(sb)
        .WithFirstLineHeader()
        )
        w.Write(p.ToDictionary(r => r.Item, r => r.Value).ToDynamic());
}

Console.WriteLine(sb.ToString());

免责声明:我是此库的作者。

您使用的是什么工具?你想要的CSV格式是什么?这是一个一次性转换还是你必须定期这样做?我正在使用C,我必须定期这样做。目的是能够阅读所有的元素的价值标签感谢您编辑您的问题,以包括预期的CSV输出从上述例子?谢谢你佐夫,这正是我要找的。我从未使用过Xslt。是否也可以像谢谢你一样对EX_挤出属性的值进行concat-User=ABC Version=1.0 Description=LastChange=41914.7876341204?除非我知道你在找什么,否则我无法编写XSLT。请编辑问题,以包含您预期的CSV输出。
XslCompiledTransform xslt = new XslCompiledTransform();
xslt.Load("C:\\XmlToCSV.xslt");
xslt.Transform("InputFile.xml", "OutputFile.csv");
string xml = @"<VWSRecipeFile>
    <EX_Extrusion User=""ABC"" Version=""1.0"" Description="""" LastChange=""41914.7876341204"">
        <Values>
            <C22O01_A_TempFZ1_Set Item=""A_TempFZ1_Set"" Type=""4"" Hex=""42700000"" Value=""60""/>
            <C13O02_A_TempHZ2_Set Item=""A_TempHZ2_Set"" Type=""4"" Hex=""43430000"" Value=""195""/>
            <C13O03_A_TempHZ3_Set Item=""A_TempHZ3_Set"" Type=""4"" Hex=""43430000"" Value=""196""/>
        </Values>
    </EX_Extrusion>
</VWSRecipeFile>";

StringBuilder sb = new StringBuilder();
using (var p = ChoXmlReader.LoadText(xml).WithXPath("/Values/*"))
{
    using (var w = new ChoCSVWriter(sb)
        .WithFirstLineHeader()
        )
        w.Write(p.ToDictionary(r => r.Item, r => r.Value).ToDynamic());
}

Console.WriteLine(sb.ToString());
A_TempFZ1_Set,A_TempHZ2_Set,A_TempHZ3_Set
60,195,196