【问题标题】:DataGridViewComboBoxColumn displaying "DataGridViewComboBoxColumn { Name=NewBox, Index=-1 }" text instead of ComboBoxDataGridViewComboBoxColumn 显示“DataGridViewComboBoxColumn { Name=NewBox, Index=-1 }”文本而不是 ComboBox
【发布时间】:2020-01-07 22:38:11
【问题描述】:

我正在制作一个简单的 Windows 窗体应用程序,它将标题从 CSV 文件导入到 DataGridView 中,然后为每一列添加一个带有组合框的行。 ComboBox 中只有一些字符串文字,但是当我运行程序并加载 CSV 时,我得到了 DataGridViewComboBoxColumn { Name=NewBox, Index=-1 }

代码如下:

using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using System.Windows.Forms;
using System.Diagnostics;

namespace DataGridTest3
{
    public partial class Form1 : Form
    {
        public Form1()
        {
            InitializeComponent();
        }

        public void button1_Click(object sender, EventArgs e)
        {
            openFileDialog1.ShowDialog();
            textBox1.Text = openFileDialog1.FileName;

            DataTable table = new DataTable();

            string[] lines = System.IO.File.ReadAllLines(textBox1.Text);
            string firstline = lines[0];
            string[] headerLabels = firstline.Split(',');
            foreach (string headerWord in headerLabels)
            {
                table.Columns.Add(new DataColumn(headerWord));
            }

            int columncount = table.Columns.Count;
            DataGridViewComboBoxColumn dgv = new DataGridViewComboBoxColumn();
            dgv.ReadOnly = false;

            dgv.Name = "NewBox";
            dgv.Items.Add("YES");
            dgv.Items.Add("NO");

            int[] columnnums = new int[columncount];

            DataRow newRow = table.NewRow();

            table.Rows.Add(newRow);

            for (int i = 0; i < columncount; i++)
            {
                newRow[i] = dgv;
            }

            dataGridView1.DataSource = table;
        }
    }
}

这是输出的截图:

【问题讨论】:

    标签: c# winforms datagridview datagridviewcomboboxcolumn


    【解决方案1】:

    试试这样:

    public void button1_Click(object sender, EventArgs e)
    {
        openFileDialog1.ShowDialog();
        textBox1.Text = openFileDialog1.FileName;
        DataTable table = new DataTable();
    
        string[] lines = System.IO.File.ReadAllLines(textBox1.Text);
        string firstline = lines[0];
        string[] headerLabels = firstline.Split(',');
        foreach (string headerWord in headerLabels)
        {
            table.Columns.Add(new DataColumn(headerWord));
        }
    
        dataGridView1.DataSource = table;
    
        DataGridViewComboBoxColumn dgv = new DataGridViewComboBoxColumn
        {
            ReadOnly = false,
            Name = "NewBox"
        };
    
        dgv.DataSource = new string[] { "YES", "NO" };
        dataGridView1.Columns.Add(dgv);
    }
    

    更新:

    public void button1_Click(object sender, EventArgs e)
    {
        openFileDialog1.ShowDialog();
        textBox1.Text = openFileDialog1.FileName;
    
        string[] lines = System.IO.File.ReadAllLines(textBox1.Text);
        string firstline = lines[0];
        string[] headerLabels = firstline.Split(',');
        foreach (string headerWord in headerLabels)
        {
            DataGridViewComboBoxColumn dgv = new DataGridViewComboBoxColumn
            {
                ReadOnly = false,
                Name = headerWord,
                DataSource = new string[] { "YES", "NO" }
            };
    
            dataGridView1.Columns.Add(dgv);
        }
    }
    

    【讨论】:

    • 在从 CSV 导入的第一个标题之前添加一个新列。下拉菜单有效,但我需要将其插入到导入标题下的第一行。
    • 你不能有不同类型的行。如果您希望第一行是 ComboBoxes,而不是所有其他行也将是 ComboBoxes。
    • 我只想要一个标题行和一个带有组合框的行。数据表永远不会有超过 1 行和一个标题行。
    猜你喜欢
    • 2018-07-14
    • 1970-01-01
    • 2017-04-05
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多