Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

How can I get the value of all the selected cells in a DataGridView?

I have a DataGridView that has MultiSelect = true. After the user selects different cells from different rows how can I get the value of all the selected cells?

like image 433
Y_Y Avatar asked Dec 30 '09 04:12

Y_Y


2 Answers

You can iterate over SelectedCells.

foreach (DataGridViewCell cell in dataGridView1.SelectedCells)
{
    MessageBox.Show(cell.Value.ToString());
}

You asked only for the value, but you probably also want to know the row and the column of the cell otherwise the value could be meaningless. You can access these also on the cell object.

like image 58
Mark Byers Avatar answered Sep 20 '22 23:09

Mark Byers


foreach -

DataGrid.SelectedCells

More info on the SelectedCells Property can be found at http://msdn.microsoft.com/en-us/library/system.windows.forms.datagridview.selectedcells.aspx

The SelectedCells collection is inefficient with large selections in DataGridView. There is a method you can use to get the count of the selected cells. iterate based on that and it'll be faster.

for (int i = 0; i < grid.GetCellCount(System.Windows.Forms.DataGridViewElementStates.Selected); i++)
{
    string val = grid.SelectedCells[i].Value;
}
like image 45
Gabriel McAdams Avatar answered Sep 21 '22 23:09

Gabriel McAdams