XDocument解析

时间:2013-07-28 03:17:23

标签: c# xml linq xml-parsing linq-to-xml

我在c#中创建了一个自定义XDocument,它看起来像下面的

<Filters datetimegenerated="28.07.2013 23:12PM">
   <SimpleStringFilter column="xxx" table="yyy" groupby="True" seperatereport="true">
   good,bad,ugly
   </SimpleStringFilter>
   <NumaricalFilter column="zzz" table = "mmm">zzz = 100 or zzz= 50</NumaricalFilter>
</Filters>    

在c#中解析它似乎不适用于我尝试解析StringFilterTags时的代码,但是我从上面的示例中得到零计数

var filters = from simplestringfilter in xdoc.Root.Element("Filters").Elements("SimpleStringFilter")
                          let column = simplestringfilter.Attribute("column")
                          let table = simplestringfilter.Attribute("table")
                          let groupby = simplestringfilter.Attribute("groupby")
                          let seperatecolumnby = simplestringfilter.Attribute("seperatereport")
                          let filterstringval = simplestringfilter.Value
                          select new
                          {

                              Column = column,
                              Table = table,
                              GroupBy = groupby,
                              SeperateColumnBy = seperatecolumnby,
                              Filterstring = filterstringval
                          };

我做错了什么?

1 个答案:

答案 0 :(得分:2)

您的查询正在搜索根元素,检查它是否具有子Filters元素。由于根 Filters元素,这显然会失败,这就是为什么你没有得到任何结果。

有两种方法可以解决此问题。只是不要搜索根目录的Filters,你的查询应该没问题。

var filters =
    from simplestringfilter in xdoc.Root.Elements("SimpleStringFilter")
    ...

更好的方法来写它恕我直言,不是查询根,而是文件本身。它看起来会更自然。

var filters =
    from simplestringfilter in xdoc.Element("Filters")
                                   .Elements("SimpleStringFilter")
    ...