C#/WPF里面DataGrid是以表格形式显示的,如何得到这个DataTable。
通常使用DataGrid,会在后台定义ObservableCollection<T>Items,然后在Xaml里面ItemsSource="{BindingItems}"...
通常使用DataGrid,会在后台定义ObservableCollection<T> Items,然后在Xaml里面ItemsSource="{Binding Items}"。我的列有些是运行的时候才添加的,会有复选框、下拉框等,用户的操作也能反映到Items。
那现在如果像要得到最终显示的表,并且希望是DataTable的类型,有没有直接从界面获取的办法?除了每行没列遍历填充DataTable以外? 展开
那现在如果像要得到最终显示的表,并且希望是DataTable的类型,有没有直接从界面获取的办法?除了每行没列遍历填充DataTable以外? 展开
展开全部
直接把数据源转换过去
如
DataGrid gd;
DataTable dt=gd.DataSource as DataTable;
如
DataGrid gd;
DataTable dt=gd.DataSource as DataTable;
追问
你没有试过吧?试过了再说。
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
虽然年代久远但为了后人还是要更正,不是没有是你不知道,把ItemSource作为DataView就可以取了,亲测可用
DataTable dt = ((DataView)dataGrid1.ItemSource).Table;
DataTable dt = ((DataView)dataGrid1.ItemSource).Table;
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
貌似没有
只能通过遍历来填充DataTable
只能通过遍历来填充DataTable
本回答被提问者采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
问题描述没有看懂??
更多追问追答
追问
简单来说,现在有一个DataGrid,里面显示了一些数据,如何在不知道后台绑定了什么数据的情况下,获取显示的数据到DataTable?
追答
你前台显示的数据是通过绑定ObservableCollection Items获得的,这里面的类的属性字段(至于里面的字段可以根据反射来获得,)对应你datatable中的一列,自己构造一个datatable
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询