1

这是我的代码:

DataSet data = new DataSet();
data.ReadXml("data.xml");

DataGridView grid = new DataGridView();

var genreCboBoxItems = data.Tables[0].AsEnumerable().Select(genre => genre.Field<string>("genre")).Distinct().ToArray();

// TODO: Make is so the 'genre' column in grid is a combo box?

grid.DataSource = data.Tables[0];
grid.Dock = DockStyle.Fill;
this.Controls.Add(grid);

*编辑:genreCboBoxItems

4

3 回答 3

2

试试这个:(未测试

var column = new DataGridViewComboBoxColumn();

column.DataSource = data.Tables[0].AsEnumerable().
      Select(genre => new { genre = genre.Field<string>("genre") }).Distinct();
column.DataPropertyName = "genre";
column.DisplayMember = "genre";
column.ValueMember = "genre";
grid.DataSource = data.Tables[0];
// Instead of the below line, You could use grid.Columns["genre"].Visible = false;
grid.Columns.Remove("genre");  
grid.Columns.Add(column);  
于 2013-05-12T16:24:21.497 回答
0

可能会帮助您将 DataGridViewColumn 转换为 DataGridViewComboBox。

于 2013-05-12T16:11:15.857 回答
0

首先使用具有正确名称的设计器创建 DataGridViewComboBoxColumn。然后说你有一个字符串列表和其他字符串值绑定到那个datagridview然后使用这个代码:下面的代码将一个列表绑定到两个DataGridViewTextBoxCell和一个DataGridViewComboBoxCell。注意 AllCriterias 是一个包含两个字符串值和一个字符串列表的列表。DGVEligibilityCriteria 是网格名称。

for (int i = 0; i < AllCriterias.Count; i++)
            {
                DataGridViewTextBoxCell Cmb1 = (DataGridViewTextBoxCell)DGVEligibilityCriteria.Rows[i].Cells[0];
                Cmb1.Value = AllCriterias[i].Name;
                DataGridViewTextBoxCell Cmb2 = (DataGridViewTextBoxCell)DGVEligibilityCriteria.Rows[i].Cells[1];
                Cmb2.Value = AllCriterias[i].Type;
                DataGridViewComboBoxCell Cmb = (DataGridViewComboBoxCell)DGVEligibilityCriteria.Rows[i].Cells[2];
                foreach (var filtervalue in AllCriterias[i].FilterValues)
                {
                    Cmb.Items.Add(filtervalue);
                }
             }

需要通过设置 selectindex 属性默认显示第一个索引。使用此代码:这里的“filterValues”是您在 datagridview 设计器中创建的 DataGridViewComboBoxCell 的名称。

foreach (DataGridViewRow  row in DGVEligibilityCriteria.Rows)
            {
                row.Cells["filterValues"].Value = (row.Cells["filterValues"] as DataGridViewComboBoxCell).Items[0];
            }
于 2015-03-25T18:12:59.620 回答