在DatagridView中添加/删除/选择ComboBox的值

时间:2012-04-25 16:18:23

标签: c# datagridview datagridviewcombobox

我正在尝试为各种格式和字段的文件自动执行数据处理任务。我创建了一个程序来确定分隔文件的分隔符,并将一大块文件加载到表单上的DataGridView中,以便用户可以在将文件批量加载到SQL表之前确认该文件的某些字段。该表将使用用户在数据网格中的组合框中选择的一些字段名称即时创建。

这是我的目标,但我不确定我是否正确接近这个问题。

此时,我为组合框创建了一个BindingSource ......

BindingSource bindingSource = new BindingSource();

这里我显示所选文件的DataGridView,为数据文件中的每个字段添加一列

    private void ShowDataGridView(string file, string delimiter, string[] fieldNames, string[] fieldLengths)
    {
        StreamReader fileReader = new StreamReader(file);
        if (bindingSource.Count == 0)
        {
            bindingSource.Add("FIRSTNAME");
            bindingSource.Add("LASTNAME");
            bindingSource.Add("ADDRESS1");
            bindingSource.Add("ADDRESS2");
            bindingSource.Add("CITY");
            bindingSource.Add("STATE");
            bindingSource.Add("ZIP");
            bindingSource.Add("COMPANY");
            bindingSource.Add("EMAIL");
            bindingSource.Add("");
        }           
        dataGridView1.Rows.Clear();
        dataGridView1.Columns.Clear();
        int count = 0;
        for (int i = 0; i < 17; i++)  //read 17 lines into datagridview for field confirmation, 17 lines just so happens to fill my datagridview nicely, last row will be combobox for field name selection
        {
            string[] fields = StringFunctions.Split(fileReader.ReadLine(), delimiter, Convert.ToString("\""));
            count = fields.Count();
            if (i == 0)
            {
               // Adding Column Header to DataGridView
                for (int x = 0; x < count; x++)
                {
                    DataGridViewTextBoxColumn columnDataGridTextBox = new DataGridViewTextBoxColumn();
                    columnDataGridTextBox.Name = fieldNames[x];
                    columnDataGridTextBox.HeaderText = fieldNames[x];
                    dataGridView1.Columns.Add(columnDataGridTextBox);
                }
            }
            dataGridView1.Rows.Add(fields);
        }

        for (int x = 0; x < count; x++)
        {
            DataGridViewComboBoxCell combobox = new DataGridViewComboBoxCell();             
            combobox.DataSource = bindingSource;
            dataGridView1[x, 16] = combobox;  //remember 17 rows added, combobox will be last row in datagridview
            combobox = null;
        }
        dataGridView1.AutoSizeColumnsMode = DataGridViewAutoSizeColumnsMode.AllCells;

        fileReader.Close();
        fileReader = null;
    }

好的,现在我可以查看数据的所有数据和组合框。某些字段是必填字段(BindingSource字段名称)我希望用户能够从组合框中为数据列选择适当的字段名称。当用户从组合框中选择一个字段时,我想从BindingSource中删除该字段名称,因此用户无法为另一列选择相同的字段名称。其余字段将具有默认字段名称,例如(FirstName,Field2,LastName,Address1,Field5,Field6,Address2等)

Combobox是我遇到问题的地方:)

我搜索了代码片段并且我正在取得一些进展,但我可以使用一些能够更好地掌握datagridview事件以及如何处理它们的人的建议。我真的不知道自己在做什么,只是扔掉墙上的东西,看它是不是粘在一起。以下是我到目前为止所尝试的......

InitializeComponent();
dataGridView1.EditingControlShowing += new DataGridViewEditingControlShowingEventHandler(DataGridViewEditingControlShowing);

private void DataGridViewEditingControlShowing(object sender, DataGridViewEditingControlShowingEventArgs e)
    {
        //here we will add the combo box's selected event changed 
        ComboBox cmbBox; 
        if (dataGridView1.CurrentCell is DataGridViewComboBoxCell)
        { 
            cmbBox = e.Control as ComboBox; 
            if (cmbBox == null)
                return; 
            cmbBox.SelectedIndexChanged += cmbBox_SelectedIndexChanged; 
        }
    }

    //This will display value of Select values of Combo Box 
    //which is DataGridView
    void cmbBox_SelectedIndexChanged(object sender, EventArgs e)
    {
        ComboBox cmbBox = (ComboBox)sender;
        if (cmbBox.SelectedValue != null)
        {
            MessageBox.Show(cmbBox.SelectedValue.ToString());  //testing
            bindingSource.Remove(cmbBox.SelectedValue);   //this removes it from the current combobox as well, no good.  Also run time error when clicking into a different combobox
        }          
    }

我希望我已经足够描述并发布了足够的代码,以便让任何可能的代码大师帮助者感受到我正在努力实现的目标。如果需要更多信息,请告诉我。非常感谢任何想法/解决方案。

谢谢!

1 个答案:

答案 0 :(得分:1)

你走在正确的轨道上,但为了实现这一点,我认为每个组合框都需要自己的数据源,因此可以单独操作它们。如果它们共享相同的源,则它们不能具有不同的内容,这就是您想要的(从组合框A中选择X应该从所有其他组合框中删除它。)

在创建组合框的循环中,“克隆”数据源,使它们各自拥有自己的数据源。