在WPF中绑定XML到DataGrid需先转为支持绑定的数据源:用DataTable.ReadXml()适合结构规整XML,自动建列;或用LINQ to XML解析为自定义对象集合,类型安全、灵活可控。

在WPF中把XML数据绑定到DataGrid,核心是把XML转换成支持绑定的数据源(如DataTable或自定义对象集合),再设置DataGrid.ItemsSource。直接绑定XDocument或XmlDocument不行,因为它们不实现IEnumerable或没提供属性供自动列生成。
DataTable.ReadXml()能直接从XML字符串、文件或流解析出表结构和数据,天然支持WPF绑定,且DataGrid.AutoGenerateColumns="True"可自动建列。
<items><item>...</item><item>...</item></items>)// 假设 XML 字符串如下:
string xml = @"<Items>
<Item><Name>苹果</Name><Price>5.2</Price></Item>
<Item><Name>香蕉</Name><Price>3.8</Price></Item>
</Items>";
DataTable dt = new DataTable();
using (var reader = XmlReader.Create(new StringReader(xml)))
{
dt.ReadXml(reader); // 自动推断列名和类型
}
dataGrid1.ItemsSource = dt.DefaultView; // 绑定 DataView,支持排序/筛选
先定义与XML元素一一对应的C#类,再用XDocument解析并投影为List<t></t>,这样能享受属性名、类型安全和绑定路径控制。
Elements()取所有同级项,Element("xxx")?.Value安全取值public class Product
{
public string Name { get; set; }
public decimal Price { get; set; }
}
// 解析
var doc = XDocument.Parse(xml);
var products = doc.Root.Elements("Item")
.Select(x => new Product
{
Name = x.Element("Name")?.Value,
Price = decimal.TryParse(x.Element("Price")?.Value, out var p) ? p : 0
}).ToList();
dataGrid1.ItemsSource = products;
绑定后还需配好XAML,否则可能不显示或列错乱:
AutoGenerateColumns="True":让DataGrid根据数据源属性自建列(对DataTable或public属性有效)Binding Path="PropertyName",比如<datagridtextcolumn header="名称" binding="{Binding Name}"></datagridtextcolumn>
Name或绑定到ViewModel属性,方便后台赋值避免踩坑:
Price ($)),建议预处理或改用自定义类INotifyPropertyChanged(仅动态更新需要)DataRowState,自定义类需实现INotifyPropertyChanged和集合变更通知(如用ObservableCollection<t></t>)基本上就这些。用DataTable最快上手,用自定义类+LINQ to XML更可控、易维护。选哪个取决于XML结构稳定性和后续扩展需求。
以上就是C#怎么把XML绑定到WPF的DataGrid的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号