我正在开发一个小工具。它将接受各种xml字符串作为输入。我想要做的是将xml (我们可以假定它是格式良好的)转换为表格格式。
我的第一个想法是使用WPF DataGrid。我尝试了下面这样的方法:
string xmlString = @"<?xml version=""1.0"" encoding=""utf-8"" ?>
<Movies xmlns="""">
<Movie Name=""Seven Samurai"" Id=""101"" Director=""Akira Kurosawa"">
<Comment Value=""1""/>
</Movie>
<Movie Name=""Happy Together"" Id=""102"" Director=""Wong Kar Wai"">
<Comment Value=""2""/>
</Movie>
<Movie Name=""Shoot The Piano Player"" Id=""103"" Director=""Francois Truffaut"">
<Comment Value=""3""/>
</Movie>
<Movie Name=""Roshomon"" Id=""104"" Director=""Akira Kurosawa"">
<Comment Value=""4""/>
</Movie>
<Movie Name=""Dead Man"" Id=""105"" Director=""Jim Jarmusch"">
<Comment Value=""5""/>
</Movie>
<Movie Name=""Children of Heaven"" Id=""106"" Director=""Majid Majidi"">
<Comment Value=""6""/>
</Movie>
</Movies>";
var sr = new StringReader(xmlString);
var dataSet = new DataSet();
dataSet.ReadXml(sr);
_dataGrid.ItemsSource = dataSet.Tables[0].DefaultView;
这将填充数据网格,但它将仅显示父行。子元素不会出现。这是因为这些元素被放入dataSet (dataSet.Tables1)的另一个表中。
我所需要的只是一个表格格式的xml的只读显示。一些排序/过滤功能会很好,但是我不知道如何(或者是否可能)以一种合理的父子格式将DataSet中的所有表放在一个DataGrid中。
我事先不知道xml的格式,所以我正在寻找一个尽可能通用的解决方案。
也许DataGrid不是理想的控件?
发布于 2015-01-27 07:04:51
您可以使用xslt转换遍历节点以将其转换为表格式
https://stackoverflow.com/questions/28159422
复制相似问题