我想知道如何从层次结构中选择一个特定的元素,以便我可以格式化它的文本。
在下面的示例中,我想格式化特定元素以删除日期的时间部分,但我也在寻找一种格式化任何元素的方法,例如在每个元素之间添加货币符号价格标签。
我的例子
<orders>
<order>
<type> tools </type> //I would like the ability to select this element
<text> screwdriver </text>
<id> 100981 </id>
<price> 5.00 </price>
<date> 01/01/15 12:51:36 </date>
</order>
<order>
<type> uniform </type>
<text> boots </text>
<id> 100546 </id>
<price> 25.00 </price>
<date> 12/01/15 15:30:41 </date>
</order>
</orders>
到目前为止我有什么
foreach (XElement element in doc.Descendants())
{
var nodes = element.Nodes().Where(p => p.NodeType == XmlNodeType.Text);
foreach (XText node in nodes)
{
node.Value = FirstLetterToUpper( node.Value );// set the first letter of each output to be uppercase
}
}
我尝试了什么
foreach (XElement element in doc.Descendants())
{
var nodes = element.Nodes().Where(p => p.NodeType == XmlNodeType.Text);
if( element.Descendants() == element.Element("date"))
{
element.Value = Convert.ToDateTime(element.Value).ToShortDateString();
}
foreach (XText node in nodes)
{
node.Value = FirstLetterToUpper( node.Value );
}
}
我有一些XML经验,但之前从未使用过XElement。
我一直在寻找一段时间,但是找不到我想要的东西。下面的答案是键入此问题的一些建议答案,但它们不提供解决方案,因为XML元素是在循环中动态生成的。
XElement node with text node has its formatting ignored
string.Format in XElement not formatting
任何对此的帮助都会很棒,因为我之前没有尝试过。谢谢。
答案 0 :(得分:2)
您可以使用Parent
属性获取文本节点的父级并检查其名称:
foreach (XText node in doc.DescendantNodes()
.Where(x => NodeType == XmlNodeType.Text))
{
if(node.Parent.Name == "date") { ... }
if(node.Parent.Name == "price") { ... }
}
顺便说一句,不要忘记在进行更改后使用XDocument.Save
方法保存文档。
答案 1 :(得分:0)
我通常创建一个类来表示xml并使用正确的类型发送对象的实例。例如convert.ToDecimal(node.innerText)