如何从xml文件中读取变量子节点?

时间:2013-12-03 12:17:44

标签: c# xml xml-parsing

我需要解析一个带有可变数量节点的xml配置文件,这些节点又包含可变数量的子节点。无论我有多少个VM节点或vmClient节点,我如何读入所有值?我在这个项目中使用C#和VS2012。 顺便说一句,如果有更好的方法来构建xml文件中的数据,请告诉我!这是xml文件:

<!--VM settings on ESX Server-->
<VM name="DE2008">
    <vmLanguage value = "de"/>
    <vmSnapshot value = "test"/>
    <vmPowerOn value = "true"/>
    <vmClients>
        <vmClient name="ITXPPRO">
            <vmClientSnapshot value="test2"/>
            <vmClientLanguage value="it"/>
        </vmClient>
        <vmClient name="JPXPPRO">
            <vmClientSnapshot value="test3"/>
            <vmClientLanguage value="jp"/>
        </vmClient>
    </vmClients>
</VM>

<VM name="FR2003">
    <vmLanguage value = "fr"/>
    <vmSnapshot value = "test"/>
    <vmPowerOn value = "true"/>
    <vmClients>
        <vmClient name="DAWIN7">
            <vmClientSnapshot value="autotc"/>
            <vmClientLanguage value="da"/>
        </vmClient>
    </vmClients>
</VM>

<!--SQL Servers used as database servers for ePO-->
<sqlServers>
    <sqlName value = "DE2008SQL"/>
    <sqlLanguage value = "de"/>
    <sqlSnapshot value = "sql"/>
</sqlServers>

2 个答案:

答案 0 :(得分:3)

我建议您使用LINQ to XML

var xdoc = XDocument.Load(path_to_xml);
var query = from vm in xdoc.Descendants("VM")
            select new {
               Name = (string)vm.Attribute("name"),
               Language = (string)vm.Element("vmLanguage").Attribute("value"),
               Snapshot = (string)vm.Element("vmSnapshot").Attribute("value"),
               PowerOn = (bool)vm.Element("vmPowerOn").Attribute("value"),
               Clients = from c in vm.Element("vmClients").Elements()
                         select new {
                            Name = (string)c.Attribute("name"),
                            // etc
                         }
            };

另外,我建议您将值直接存储为元素值,或者存储在属性中,而不是

Language = (string)vm.Element("vmLanguage").Attribute("value")

您将能够使用(如果缺少某些元素,您也不会获得异常)

Language = (string)vm.Element("vmLanguage") // if value stored in element
// or
Language = (string)vm.Attribute("vmLanguage") // if value stored in attribute

前缀vm对我来说有点奇怪。如果它是language数据的一部分,为什么不简单地使用vm?所以,我会采用以下配置:

<vm name="DE2008" language="de" shapshot="test" powerOn="true">
    <clients>
        <client name="ITXPPRO" snapshot="test2" language="it"/>
        <client name="ITXPPRO" snapshot="test3" language="jp"/>
    </clients>
</vm>

答案 1 :(得分:1)

你只是使用这样的东西

    XDocument xDocument = XDocument.Load(yourconfigfilepath);


            var firstresult = xDocument.Descendants("VM");
foreach (var elt in result)
            {
                var childforeachNode = xDocument.Descendants("vmClient");

            }