将DataGridView内容复制到多个TextBoxes

时间:2013-04-21 00:10:01

标签: c# sql winforms datagridview textbox

我有一个包含3列的DataGridView,我希望当我单击一个单元格时,它的内容将被复制到2个不同的文本框和1个组合框中。到目前为止,我唯一能做到的就是这样:

        private void dataGridView1_CellContentClick(object sender, DataGridViewCellEventArgs e)
    {
        dataGridView1.Rows.CopyTo = txtCveMun.Text;
    }

以上根本不起作用,这只是我搞乱图书馆的事情。 所以我该怎么做?谢谢!

如果有人关心,这是我填写DataGridView的方法:

private void CargaDataGridView()
    {
        conexion.Open();
        try
        {
            cmd.CommandText = "SELECT m.cvemunicipio, m.nombre AS NombreA, e.nombre AS NombreB FROM tbMunicipios m INNER JOIN tbEstados e ON m.CveEstado = e.CVeEstado";
            rd = cmd.ExecuteReader();
            while (rd.Read())
            {
                this.dataGridView1.Rows.Add(rd.GetValue(0), rd.GetValue(1), rd.GetValue(2));
            }
            conexion.Close();
        }
        catch (Exception ex)
        {
            MessageBox.Show(ex.Message, Application.ProductName, MessageBoxButtons.OK, MessageBoxIcon.Error);
        }
    }

修改

完整的答案是

private void dataGridView1_DoubleClick(object sender, EventArgs e)
    {
        txtCveMun.Text = dataGridView1.SelectedRows[0].Cells["Column1"].Value.ToString();
        txtNomMun.Text = dataGridView1.SelectedRows[0].Cells["Column2"].Value.ToString();
        cbEstado.Text = dataGridView1.SelectedRows[0].Cells["Column3"].FormattedValue.ToString();
    }

2 个答案:

答案 0 :(得分:0)

首先,您必须将DatagridView选择模式设置为FullRowSelect,然后您可以通过以下方式获取列的值:

dataGridView1.SelectedRows[0].Cells["ColummName"].Value.ToString();

答案 1 :(得分:0)

如果要将内容从DataGridView复制到控件(例如文本框),可以使用行和单元格集合来获取CellContentClick事件中的单元格值。

private void dataGridView1_CellContentClick(object sender, DataGridViewCellEventArgs e)
{
    txtCveMun.Text = dataGridView1.Rows[e.RowIndex].Cells[e.ColumnIndex].Value.ToString();
}

如果要从当前行获取单元格的值,则可以使用列名称。

private void dataGridView1_CellContentClick(object sender, DataGridViewCellEventArgs e)
{
    txtCveMun.Text = dataGridView1.Rows[e.RowIndex].Cells["gridViewColumnName1"].Value.ToString();
    txtSomeControl.Text = dataGridView1.Rows[e.RowIndex].Cells["gridViewColumnName2"].Value.ToString();    
}