Warning: file_get_contents(/data/phpspider/zhask/data//catemap/2/csharp/299.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#LINQ从XElement获取属性值_C#_Xml_Linq_Xelement_Xattribute - Fatal编程技术网

c#LINQ从XElement获取属性值

c#LINQ从XElement获取属性值,c#,xml,linq,xelement,xattribute,C#,Xml,Linq,Xelement,Xattribute,我在数据定义文件中有以下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="T

我在数据定义文件中有以下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"  />
现在我需要获取属性documentType的值,因此我尝试了以下LINQ表达式:

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

reportName = repName.ToString();
不幸的是,尽管我可以看到value TransList是reportName元素的一部分,但我没有找到它

以下是VS 2013中的一张图片:


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

Linq查询返回集合。对每个执行
repName

repName.First().ToString()

如果这就是您所需要的。

Linq查询返回集合。对每个执行
repName

repName.First().ToString()

这是因为
repName
将为所有
mapInfo
返回一个
IEnumerable

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

这是因为
repName
将为所有
mapInfo
返回一个
IEnumerable

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

您的解决方案取决于XML中存在多少元素
DocumentType
。如果只有一个(我想是这样),您可以使用
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());

它将返回一个枚举。

您的解决方案取决于XML中存在多少元素
DocumentType
。如果只有一个(我想是这样),您可以使用
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());
它将返回一个枚举。

更改

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

然后
mapInfo.First()
将为您提供所需的值。

更改

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


然后
mapInfo.First()
将为您提供所需的值。

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

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

另外,您不需要在
XAttribute.Value
上调用
ToString()
,因为它已经是
字符串了

要从LINQ查询中获取单个值,您必须调用例如
First
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();
另外,您不需要在
XAttribute.Value
上调用
ToString()
,因为它已经是
字符串了