Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

.NET / C# Binding IList<string> to a DataGridView

I have an IList<string> returning from a function (as variable lst) and I set and then I

this.dataGridView1.DataSource = lst;

The datagrid adds one column labelled Length and then lists the length of each string. How do I make it just list the strings?

like image 349
BuddyJoe Avatar asked Jul 09 '09 14:07

BuddyJoe


2 Answers

You really need a list of objects that have a string property. With .NET 3.5 you could cheat:

.DataSource = list.Select(x=>new {Value = x}).ToList();

Otherwise create a dummy class and copy the data in manually...

like image 171
Marc Gravell Avatar answered Oct 30 '22 16:10

Marc Gravell


This is because DataGridViews show properties of the object. In this case the List only has one property "Length", therefore it can only display "Lenght" (regardless of DataType). You need to create a wrapper class to achieve what you want (a "MyString" class with a property of "Text", then have a List displayed in your grid).

Hope this helps

Adding Code Example

 class MyString
    {
        private string _text;
        public string Text
        { get 
             { 
              return _text; 
             }
            set 
            {
                _text = value; 
            }
        }

    }

'In the executing form

 private List<MyString> foo()
        {
            List<MyString> lst = new List<MyString>();
            MyString one = new MyString();
            MyString two = new MyString();
            one.Text = "Hello";
            two.Text = "Goodbye";
            lst.Add(one);
            lst.Add(two);
            return lst;
        }

        private void Form1_Load(object sender, EventArgs e)
        {
            dataGridView1.DataSource = foo();

        }
like image 37
Ben Avatar answered Oct 30 '22 17:10

Ben