从DataGridView中获取选定列的计数
本文关键字:DataGridView 获取 | 更新日期: 2023-09-27 18:10:22
我有什么:
- 填充datagridview
- 此网格的选定单元格
What do I want:
- 所选单元格的唯一列数
- 列名
发现:
int selectedColumnsCount = dataGridView3.SelectedColumns.Count;
不知何故,这段代码在我的情况下不起作用。
我的问题:如何获得从DataGridView
中选择的列名称和列数量?
这是我现在创建的:
int selectedCellCount = dataGridView3.GetCellCount(DataGridViewElementStates.Selected);
int selectedcolumncount = dataGridView3.SelectedColumns.Count;
ArrayList arr = new ArrayList();
int j = 0;
if (selectedCellCount > 0)
{
for (int i = 0; i < selectedCellCount; i++)
{
int Xcor2 = int.Parse(dataGridView3.SelectedCells[i].ColumnIndex.ToString());
test = test + dataGridView3.Columns[Xcor2].Name;
arr.Add(dataGridView3.Columns[Xcor2].Name);
}
}
ArrayList arr2 = new ArrayList();
foreach (string str in arr)
{
if (!arr2.Contains(str))
{
arr2.Add(str);
j++;
}
}
这是我自己做的,不是很好,但它可以得到列的计数如果有人有更好的方法来实现这一点,请随时添加
可以注册SelectionChanged
事件,处理SelectedCells
事件。例如
public Form1()
{
InitializeComponent();
dataGridView1.SelectionChanged += new EventHandler(dataGridView1_SelectionChanged);
}
HashSet<int> column_indicies = new HashSet<int>();
HashSet<string> column_names = new HashSet<string>();
int number_of_columns = 0;
void dataGridView1_SelectionChanged(object sender, EventArgs e)
{
column_indicies.Clear();
column_names.Clear();
foreach (DataGridViewCell cell in dataGridView1.SelectedCells)
{
// Set of column indicies
column_indicies.Add(cell.ColumnIndex);
// Set of column names
column_names.Add(dataGridView1.Columns[cell.ColumnIndex].Name);
}
// Number of columns the selection ranges over
number_of_columns = column_indicies.Count;
}
不能选择列。一次只能选择一个列!列和行是一样的。或者您的意思是获得那些列,哪些单元格被选中?
好的,这是获取列名的一种方法(你甚至可以使用HeaderText属性代替Name):
List<DataGridViewColumn> listOfColumns = new List<DataGridViewColumn>();
foreach (DataGridViewCell cell in dataGridView1.SelectedCells)
{
DataGridViewColumn col = dataGridView1.Columns[cell.ColumnIndex] as DataGridViewColumn;
if (!listOfColumns.Contains(col))
listOfColumns.Add(col);
}
StringBuilder sb =new StringBuilder();
foreach (DataGridViewColumn col in listOfColumns)
sb.AppendLine(col.Name);
MessageBox.Show("Column names of selected cells are:'n" + sb.ToString());