首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >c# LINQ从XElement获取属性值

c# LINQ从XElement获取属性值
EN

Stack Overflow用户
提问于 2015-09-01 10:12:00
回答 5查看 4.1K关注 0票数 0

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

代码语言:javascript
运行
复制
<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"  />

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

代码语言:javascript
运行
复制
var mapInfo = from nm in XElement.Elements("PQTemplate")
                where (string)nm.Attribute("documentID") == sRequests[0].Split('\t')[0] 
                select nm;    

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

代码语言:javascript
运行
复制
var repName = from d in mapInfo.Attributes("documentType")
                     select d.Value;

reportName = repName.ToString();

不幸的是,虽然我可以看到值TransList是reportName元素的一部分,但我没有成功地尝试检索它。

下面的图片显示在VS 2013中:

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

EN

回答 5

Stack Overflow用户

回答已采纳

发布于 2015-09-01 10:18:58

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

代码语言:javascript
运行
复制
IEnumerable<string> repName = from d in mapInfo.Attributes("documentType")
                     select d.Value;

所以,要么使用foreach循环,如果您怀疑您可能获得更多的值,或者使用First获取第一个属性,如下所示:

代码语言:javascript
运行
复制
string reportName = mapInfo.First().Attribute("documentType").Value;
票数 2
EN

Stack Overflow用户

发布于 2015-09-01 10:18:41

Linq查询返回集合。在for each上执行repName

代码语言:javascript
运行
复制
repName.First().ToString()

如果这是你所需要的。

票数 1
EN

Stack Overflow用户

发布于 2015-09-01 10:23:07

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

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

代码语言:javascript
运行
复制
var result = new List<string>();
foreach(var a in (from d in mapInfo.Attributes("documentType") select d.Value) 
    result.Add(a.ToString());

甚至更短:

代码语言:javascript
运行
复制
result = mapInfo.Attributes("documentType").Select(x => x.Value.ToString());

它将返回一个枚举。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/32328965

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档