c# LINQ 从 XElement 获取属性值
c# LINQ get Attribute value from XElement
我在数据定义文件中有以下 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" />
我使用 LINQ 获取特定的 XElement,使用以下 LINQ 表达式从包含多个 PQTemplate
元素的 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();
不幸的是,虽然我可以看到值 TransList 是 reportName 元素的一部分,但我没有成功地尝试检索它。
这是在 VS 2013 中显示的图像:
那么如何获取元素中的 documentType
属性呢?
Linq 查询 return 个集合。在 repName
或
上做 for each
repName.First().ToString()
如果这就是您所需要的。
那是因为 repName
将 return 一个 IEnumerable<string>
用于所有 mapInfo
。
IEnumerable<string> repName = from d in mapInfo.Attributes("documentType")
select d.Value;
因此,如果您怀疑您可能会获得更多值,请使用 foreach
循环,或者使用 First
来获取第一个属性,如下所示:-
string reportName = mapInfo.First().Attribute("documentType").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());
或更短:
result = mapInfo.Attributes("documentType").Select(x => x.Value.ToString());
这将 return 枚举。
改变
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()
会给你想要的值。
要从 LINQ 查询中获取单个值,您必须调用 First
或 FirstOrDefault
。如果您调用 FirstOrDefault
如果查询 returns 没有匹配,它不会抛出异常。
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()
,因为它已经是 string
。
我在数据定义文件中有以下 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" />
我使用 LINQ 获取特定的 XElement,使用以下 LINQ 表达式从包含多个 PQTemplate
元素的 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();
不幸的是,虽然我可以看到值 TransList 是 reportName 元素的一部分,但我没有成功地尝试检索它。
这是在 VS 2013 中显示的图像:
那么如何获取元素中的 documentType
属性呢?
Linq 查询 return 个集合。在 repName
或
for each
repName.First().ToString()
如果这就是您所需要的。
那是因为 repName
将 return 一个 IEnumerable<string>
用于所有 mapInfo
。
IEnumerable<string> repName = from d in mapInfo.Attributes("documentType")
select d.Value;
因此,如果您怀疑您可能会获得更多值,请使用 foreach
循环,或者使用 First
来获取第一个属性,如下所示:-
string reportName = mapInfo.First().Attribute("documentType").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());
或更短:
result = mapInfo.Attributes("documentType").Select(x => x.Value.ToString());
这将 return 枚举。
改变
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()
会给你想要的值。
要从 LINQ 查询中获取单个值,您必须调用 First
或 FirstOrDefault
。如果您调用 FirstOrDefault
如果查询 returns 没有匹配,它不会抛出异常。
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()
,因为它已经是 string
。