我一直在寻找将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_Set,A_TempHZ2_Set,A_TempHZ3_Set
60195195
我可以实现新的预期csv格式,但不知道这是否是最佳方式,任何建议都表示赞赏
<?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:for-each select="EX_Extrusion/Values/*">
<xsl:value-of select="concat(@Item,',')" />
</xsl:for-each>
<xsl:text>
</xsl:text>
<xsl:for-each select="EX_Extrusion/Values/*">
<xsl:value-of select="concat(@Value,',')" />
</xsl:for-each>
<xsl:text>
</xsl:text>
</xsl:template>
</xsl:stylesheet>'
由于
答案 0 :(得分:1)
您可以这样做的一种方法是使用XSLT,这是一种用于处理XML的语言。你肯定可以用C#解析XML,但我喜欢XSLT,因为它更清晰。
定义外部XSLT文件,然后在C#中调用它来进行转换。
修改:根据新要求添加新列。
文件C:\ XmlToCSV.xslt(

是换行符)
<?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
</xsl:text>
<xsl:for-each select="EX_Extrusion/Values/*">
<xsl:value-of select="concat(@Item,',',@Type,',',@Hex,',',@Value,',',$User,',',$Version,',',$Description,',',$LastChange,'
')"/>
</xsl:for-each>
</xsl:template>
</xsl:stylesheet>
使用XslCompiledTransform
:
XslCompiledTransform xslt = new XslCompiledTransform();
xslt.Load("C:\\XmlToCSV.xslt");
xslt.Transform("InputFile.xml", "OutputFile.csv");
根据您的需要进行调整。
答案 1 :(得分:0)
基本思路是iterate though values nodes并为每个节点选择所需的属性,并使用逗号分隔符将它们写入文件。只需将文件命名为.csv即可。如果您想要现成的东西,请检查this。
答案 2 :(得分:0)
XSLT是一种方法。或者,您可以使用Cinchoo ETL - 一个可用于解析xml的开源库,以您希望的方式生成CSV。
innerHTML
输出:
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());
免责声明:我是这个图书馆的作者。