0

我在数据定义文件中有以下 XML:

<PQTemplate documentID="CSTrlsEN" documentType="TransList" templateID="001" 
        templateType="Customer Copy" 
        templateName="C:\CPS\_templates\Mini-Statements\CSTrlsEN.doc">  
<field pos="5" name="YPTME" descr="Time"  />
<field pos="6" name="YPDTE" descr="Action Date"  />
<field pos="7" name="YPBRNO" descr="Branch Number"  />
<field pos="8" name="YPBNA" descr="Branch Name"  />
<field pos="9" name="YPTID" descr="Teller ID"  />
<field pos="10" name="YPISN" descr="Teller Sequence"  />
<field pos="11" name="YPREF" descr="Customer Reference"  />
<field pos="12" name="YPCUS" descr="Customer Name"  />
<field pos="13" name="YPEAN" descr="Account Number"  />
<field pos="14" name="YPATY" descr="Account Type"  />
<field pos="15" name="YPCUR" descr="Currency"  />
<field pos="16" name="YPBAL" descr="Available Balance"  />

PQTemplate我使用 LINQ 获取特定的 XElement,并使用以下 LINQ 表达式从包含多个元素的 XML 文件中提取它:

var mapInfo = from nm in XElement.Elements("PQTemplate")
                where (string)nm.Attribute("documentID") == sRequests[0].Split('\t')[0] 
                select nm;    

现在我需要获取属性documentType的值,所以我尝试了下面的 LINQ 表达式:

var repName = from d in mapInfo.Attributes("documentType")
                     select d.Value;

reportName = repName.ToString();

不幸的是,虽然我可以看到值TransListreportName元素的一部分,但我没有运气尝试检索它。

这是在 VS 2013 中显示的图像:

在此处输入图像描述

那么如何获取documentType元素中的属性呢?

4

5 回答 5

2

那是因为repName将为IEnumerable<string>所有mapInfo.

IEnumerable<string> repName = from d in mapInfo.Attributes("documentType")
                     select d.Value;

因此,foreach如果您怀疑您可能会获得更多值,请使用循环或用于First获取第一个属性,如下所示:-

string reportName = mapInfo.First().Attribute("documentType").Value;
于 2015-09-01T10:18:58.127 回答
1

DocumentType您的解决方案取决于您的 XML 中存在多少元素。如果它只有一个(我想),你可以使用repName.First().ToString().

如果该属性可能多次出现,则应使用循环:

var result = new List<string>();
foreach(var a in (from d in mapInfo.Attributes("documentType") select d.Value) 
    result.Add(a.ToString());

甚至更短:

result = mapInfo.Attributes("documentType").Select(x => x.Value.ToString());

这将返回一个枚举。

于 2015-09-01T10:23:07.487 回答
1

改变

var mapInfo = from nm in XElement.Elements("PQTemplate")
                where (string)nm.Attribute("documentID") == sRequests[0].Split('\t')[0] 
                select nm;   

var mapInfo = from nm in XElement.Elements("PQTemplate")
                where (string)nm.Attribute("documentID") == sRequests[0].Split('\t')[0] 
                select nm.Attribute("documentType").Value;   

然后 mapInfo.First()会给你你想要的价值。

于 2015-09-01T10:30:14.360 回答
1

要从 LINQ 查询中获取单个值,您必须调用例如Firstor FirstOrDefault。如果查询没有返回匹配项,则调用FirstOrDefault它不会引发异常。

string repName =  doc.Elements("PQTemplate")
                     .Where(e => (string)a.Attribute("documentID") == sRequests[0].Split('\t')[0])
                     .Select(e => (string)e.Attribute("documentType"))
                     .FirstOrDefault();

此外,您不需要调用ToString()XAttribute.Value因为它已经是string.

于 2015-09-01T10:54:39.690 回答
1

Linq 查询返回集合。重做或for each_repName

repName.First().ToString()

如果这就是你所需要的。

于 2015-09-01T10:18:41.487 回答