繁体   English   中英

如何通过列名获取列索引?

[英]how to get column Index by column name?

我有一个列数很少的数据网格-

网格的标题是超链接,我在运行时设置它的值如下-

string strQ1 = "<a href='somePage.aspx?ID=1'>gfgytyty<a>";
dtGrid.Columns[0].Header = strq1;

string strQ2 = "<a href='somePage.aspx?ID=2'>yhtryrtuyu<a>";
dtGrid.Columns[1].Header = strq2;

and so on...

它工作正常。 现在假设我想通过名称获取 datatgrid 特定列的索引,但我无法获取它。 我试过

int  colIndex = dtGrid.Columns.IndexOf(dtGrid.Columns[strQ2]);

这应该返回 1 作为 columnIndex 但它返回 -1,

此外, dtGrid.Columns[strQ2] 给我空值。

我在这里做错了什么?

您可以先使用 LINQ FirstOrDefault 获取对象,然后才使用 .IndexOf(object) :

var targetColumn = dtGrid.Columns.FirstOrDefault(c => c.Header == strQ2);
var index = dtGrid.Columns.IndexOf(targetColumn);

这是使用List.FindIndex的另一种方法:

int index = dtGrid.Columns.ToList().FindIndex(c => c.Header  == strQ2);

如果它不是 WPF DataGrid (这似乎是由于Header属性)而是一个没有实现泛型集合类型的 winforms DataGridView ,则您需要先对其进行转换,然后才能使用 LINQ 方法:

var columnList = dtGrid.Columns.Cast<DataGridViewColumn>().ToList();
int index = columnList.FindIndex(c => c.HeaderText  == strQ2);

为什么不呢?

int index = myDataGridView.Columns["myColumn"].Index;

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM