[英]C# split xml innertext or parse innerxml
我有一个结构与此类似的XML文件
<entry name="something">
<members>
<member>aaa</member>
<member>bbb</member>
</members>
</entry>
<entry name="something_else">
<members>
<member>ccc</member>
<member>ddd</member>
</members>
</entry>
我需要能够从每个成员节点中获取值以存储在数据表中。 如果我使用innertext属性,它将连接值(aaabbb)。 没有任何可分割的字符串。 我也可以使用内部XML,但是随后我得到的是XML结构的字符串(aaa bbb <\\ member>)
从XML元素中获取每个值并将其存储在字符串数组中的最佳方法是什么?
这是我一直在尝试的。
foreach (XmlNode grpNode in GrpList)
{
subNode = grpNode.Attributes["name"];
if (subNode != null)
{
Obj = grpNode.Attributes["name"].Value;
}
subNode = grpNode["members"];
if (subNode != null)
{
string innerXml = string.Empty;
innerXml = grpNode["members"].InnerXml.ToString();
string[] tempArrary = innerXml.Split(new char[] {'>', '<'});
}
}
您可以使用Xpath遍历Entry节点并像这样获取其中的成员
string xml = "<root><entry name='something'>" + "<members>" + "<member>aaa</member>" + "<member>bbb</member>" + "</members>" + "</entry>" + "<entry name='something_else'>" + "<members>" + "<member>ccc</member>" + "<member>ddd</member>" + "</members>" + "</entry></root>"; XmlDocument doc = new XmlDocument(); doc.LoadXml(xml); var memsList = doc.SelectNodes("//entry"); foreach (XmlNode a in memsList) { Console.WriteLine(a.Attributes["name"].Value); var memList = a.SelectNodes("members/member"); foreach(XmlNode x in memList) Console.WriteLine(x.InnerText); }
您需要遍历内的子元素members
,所以是这样的:
foreach (var node in grpNode["members"].ChildNodes)
{
var value = node.InnerText;
}
就是说,最好使用LINQ to XML,除非您有特定的理由使用XmlDocument
。 这为您提供了更具表现力的代码,例如:
var doc = XDocument.Parse(xml);
var something = doc.Descendants("entry")
.Where(e => (string)e.Attribute("name") == "something")
.Single();
var somethingMembers = something.Descendants("member")
.Select(e => e.Value)
.ToArray();
这应该可以解决问题:
XDocument xdoc = XDocument.Load(@"Path/to/file");
var result = xdoc.Descendants("member").Select (x => x.Value).ToArray();
结果:
您提供的xml无效。 但是,假设您只想将所有member
节点的内部文本转换为字符串数组,则只使用Linq-To-Xml(XDocument):
var results = XDocument.Parse(xmlString)
.Descendants("member")
.Select(m => m.Value)
.ToArray();
即使您使用的是旧版XmlDocument
API,也可以通过抛出.OfType<XmlNode>()
来将XmlNodeList
转换为通用枚举,从而混合使用一些linq和lambda语法,例如:
var tempArrary = subNode.SelectNodes("member").OfType<XmlNode>().Select(n => n.InnerText).ToArray();
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.