如何读取多列ListView控件的列名?

Rol*_*and 2 c# listview multiple-columns

查找ListView列的名称的最佳方法是什么?

我使用我在此论坛上找到的程序将DataTable转换为List,但我无法将Id列放在第一位,特别是因为并非我的所有DataTable都有一列"Id".

我可以在集合listView.Columns.ToString()中搜索,但我看到的格式是:

"ColumnHeader:Text:Id"

我必须解析,找到正确的名称"Id".这看起来不像C#的精神.

我也尝试过:listView.SelectedItems[0].SubItems["Id"] 但是没有编译.


好的这是完整的代码.确切的问题是用户使用Courier Names和Ids在listView中选择一行,但它也可以是Ids和Names.找到所选快递的ID的最快方法是:

ListViewItem si = listCouriers.SelectedItems[0];
CourierId = si.SubItems["Id"].Text;
Run Code Online (Sandbox Code Playgroud)

但这不起作用.硬编码的方式就是这样,但我不能保证有一天会使用错误的列:

ListViewItem si = listCouriers.SelectedItems[0];
CourierId = si.SubItems[1].Text;
Run Code Online (Sandbox Code Playgroud)

使用@HuorSwords方法导致这个不那么简单的解决方案,这对我有用,但取决于合理的假设,即列中的列顺序ColumnHeaderCollection对应于表单上的显示:

ListViewItem si = listCouriers.SelectedItems[0];
string CourierId = null;
int icol = 0;
foreach (ColumnHeader header in listCouriers.Columns)
{
    if (header.Text == "Id")
    {
        CourierId = si.SubItems[icol].Text;
        break;
    }
    icol++;
}
Run Code Online (Sandbox Code Playgroud)

Huo*_*rds 6

作为listView.Columns类型ListView.ColumnHeaderCollection,它包含ColumnHeader对象.

ColumnHeader.Text包含列标题,这样你就可以检查与混凝土柱:

foreach (ColumnHeader header in listView.Columns)
{
      if (header.Text == "Id")
      {
           // Do something...
      }
}
Run Code Online (Sandbox Code Playgroud)

我不知道是否是最好的方法,但你不需要解析结果来找到"Id"值...

UPDATE

此外,您是否尝试使用String索引器引用它?>listView.Columns["Id"]