我想在xml文件中更改“NextMemberId”的属性值(在本例中为“51”),如下所示:
<File>
<MemberList>
<NextMemberId Value="51" />
<Member Id="1" ..... />
<Member Id="2" ..... />
</MemberList>
</File>
以下代码有效,但我想知道是否可以以更直接的方式完成而无需运行foreach循环:
var memberId = 1;
var memberlist = Doc.DocumentElement.SelectSingleNode("MemberList");
foreach (XmlNode node in memberlist.ChildNodes)
{
var nodeElement = node as XmlElement;
if (nodeElement != null && nodeElement.Name == "NextMemberId")
{
nodeElement.SetAttribute("Value", memberId.ToString());
}
}
感谢您的灵感!
解决方法:
根据您的示例XML从File获取NextMemberId的正确路径是:
var nodeElement = Doc.DocumentElement.SelectSingleNode("MemberList/NextMemberId");
nodeElement.SetAttribute("Value", memberId.ToString());
如果您的实际XML中有多个NextMemberId,并且您需要按Value属性进行过滤,那么您可以添加类似于其他答案建议的XPath谓词:
var nodeElement = Doc.DocumentElement.SelectSingleNode("MemberList/NextMemberId[@Value=51");
请注意,您可以选择在51左右保留或保留单引号,具体取决于您是要将值分别比较为字符串还是数字.
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。