C#/WPF里面DataGrid是以表格形式显示的,如何得到这个DataTable。

通常使用DataGrid,会在后台定义ObservableCollection<T>Items,然后在Xaml里面ItemsSource="{BindingItems}"... 通常使用DataGrid,会在后台定义ObservableCollection<T> Items,然后在Xaml里面ItemsSource="{Binding Items}"。我的列有些是运行的时候才添加的,会有复选框、下拉框等,用户的操作也能反映到Items。
那现在如果像要得到最终显示的表,并且希望是DataTable的类型,有没有直接从界面获取的办法?除了每行没列遍历填充DataTable以外?
展开
 我来答
百度网友7695b6b
2013-09-16 · TA获得超过165个赞
知道小有建树答主
回答量:126
采纳率:0%
帮助的人:120万
展开全部
直接把数据源转换过去

DataGrid gd;
DataTable dt=gd.DataSource as DataTable;
追问
你没有试过吧?试过了再说。
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
冰冻双侠II
2017-08-02 · TA获得超过835个赞
知道小有建树答主
回答量:130
采纳率:75%
帮助的人:77.1万
展开全部
虽然年代久远但为了后人还是要更正,不是没有是你不知道,把ItemSource作为DataView就可以取了,亲测可用

DataTable dt = ((DataView)dataGrid1.ItemSource).Table;
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
RXC55555
2013-09-16 · TA获得超过135个赞
知道小有建树答主
回答量:121
采纳率:0%
帮助的人:116万
展开全部
貌似没有

只能通过遍历来填充DataTable
本回答被提问者采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
dog7878
2013-09-15 · 超过11用户采纳过TA的回答
知道答主
回答量:50
采纳率:0%
帮助的人:35.5万
展开全部
问题描述没有看懂??
更多追问追答
追问
简单来说,现在有一个DataGrid,里面显示了一些数据,如何在不知道后台绑定了什么数据的情况下,获取显示的数据到DataTable?
追答
你前台显示的数据是通过绑定ObservableCollection Items获得的,这里面的类的属性字段(至于里面的字段可以根据反射来获得,)对应你datatable中的一列,自己构造一个datatable
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 3条折叠回答
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式