如何将在dataGridView1控件中选中的行复制到dataGridView2

shijies 2021-03-01 09:29:14
用以下的代码并不能够实现,不知何故?

foreach (DataGridViewRow r in dataGridView1.SelectedRows)
{
if (!r.IsNewRow)
{
dataGridView2.Rows.Add(r);
}
}
...全文
362 10 打赏 收藏 转发到动态 举报
AI 作业
写回复
用AI写文章
10 条回复
切换为时间正序
请发表友善的回复…
发表回复
  • 打赏
  • 举报
回复
提醒一下,一般来说,任何公司级的研发,都会注重对设计规范的“道”的层面的设计研发。遇到一些喜欢拼凑各种控件、针对微软的成熟控件进行编程的人,其实知道是浪费资金,那类程序难以复用,性价比很低。
  • 打赏
  • 举报
回复
微软设计的(各种)组件,都有一个基本的规范,很稳定靠谱,就是任何组件都只能放到一个容器组件中。一旦你放入另外一个组件容器,(内部实现机制)就会自动从原来的容器中删除父子关系。 从设计上说,对于程序设计师的基本要求是,要懂得的“MVVM”基本设计规范,也就是 View 和所绑定的数据结构相分离的基本规范。数据列表未必就要用 GridView,可能随时改为其它的 UI 控件。因此设计层次不可乱用。要表达数据驱动的设计,就要从数据结构上来说明流程。当第一个 GridView 控件捕获到一些用户操作之后,那么改变了第一个GridView 所绑定的数据源,并且将改变的数据对象插入第二个 GridView 所绑定的数据源,于是第二个GridView就刷新了。 这个过程中丝毫不直接涉及到 UI 控件概念,仅仅是控件背后所绑定的数据集合改变了,于是 GridView 就自动刷新了。
shijies 2021-03-05
  • 打赏
  • 举报
回复
又改了一次,先生成一个与DataGridView1绑定的数据表结构一样的空表,再将空表绑定到DataGridView2,代码如下: DataTable dm = new DataTable(); DataColumn comName = new DataColumn("商品名", typeof(string)); DataColumn comPrice = new DataColumn("价格", typeof(int)); DataColumn comInventory = new DataColumn("库存", typeof(int)); dm.Columns.Add("商品名", typeof(string)); dm.Columns.Add("价格", typeof(int)); dm.Columns.Add("库存", typeof(int)); dataGridView2.DataSource = dm; int index = dataGridView1.CurrentRow.Index; a = new string[dataGridView1.ColumnCount]; for (int i = 0; i < dataGridView1.ColumnCount; i++) { a[i] = dataGridView1.Rows[index].Cells[i].Value.ToString(); } for (int i = 0; i < dataGridView2.ColumnCount; i++) dataGridView2.Rows[dataGridView2.RowCount - 2].Cells[i].Value = a[i]; // 这一行有问题 编译后,运行出现异常: ************** 异常文本 ************** System.ArgumentOutOfRangeException: 索引超出范围。必须为非负值并小于集合大小。
changjiangzhibin 2021-03-05
  • 打赏
  • 举报
回复
1、保证两个DataGridView的列数/对应数据类型是相同的
shijies 2021-03-05
  • 打赏
  • 举报
回复
下面这行代码不是创建了列? DataGridTextBoxColumn tb = new DataGridTextBoxColumn();
shijies 2021-03-05
  • 打赏
  • 举报
回复
把代码改了一下,声明了一个数组a,把一个dataGridView一行的所有列的值存进数组,再将数组的值依次赋给另一个dataGridView控件的一行,代码如下: public static string[] a; int index = dataGridView1.CurrentRow.Index; a = new string[dataGridView1.ColumnCount]; for (int i = 0; i < dataGridView1.ColumnCount; i++) { a[i] = dataGridView1.Rows[index].Cells[i].Value.ToString(); } DataGridTextBoxColumn tb = new DataGridTextBoxColumn(); dataGridView2.Rows.Add(tb); for (int i = 0; i < dataGridView2.ColumnCount; i++) dataGridView2.Rows[dataGridView2.RowCount - 2].Cells[i].Value = a[i]; 可是运行程序却出现了异常,提示信息如下: ************** 异常文本 ************** System.InvalidOperationException: 不能向没有列的 DataGridView 控件添加行。必须首先添加列。 在 System.Windows.Forms.DataGridViewRowCollection.AddInternal(Boolean newRow, Object[] values)
shensi88 2021-03-02
  • 打赏
  • 举报
回复
操作2个数组不就可以
shijies 2021-03-01
  • 打赏
  • 举报
回复
如果让内存表dtt绑定到dataGridView2,如: dataGridView2.DataSource = dtt; 然后将在dataGridView1控件中选中的行复制到dataGridView2,使用下面的语句,还是不行。 foreach (DataGridViewRow r in dataGridView1.SelectedRows) { if (!r.IsNewRow) { dtt.Rows.Add(r); } }
  • 打赏
  • 举报
回复
那就换种方式用数组的方式可参获取数组的值去做处理
  • 打赏
  • 举报
回复
应该将1的数据添加到2的绑定数据源中去.

111,092

社区成员

发帖
与我相关
我的任务
社区描述
.NET技术 C#
社区管理员
  • C#
  • AIGC Browser
  • by_封爱
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

让您成为最强悍的C#开发者

试试用AI创作助手写篇文章吧