Как изменить код для получения конкретного столбца в datagridview? - PullRequest
4 голосов
/ 11 июля 2011

У меня есть список данных в datagridview.Например, один столбец имеет имя Class (каждая строка имеет свое значение, см. Ниже). Возможно ли иметь поле со списком, содержащее все возможные значения Class записи в поле со списком?* Должен быть список из 6А, 6В, 6С Если позднее в базу данных будет добавлено больше классов (пример 6D), они также должны быть в выпадающем списке. *

Представление datagridview

Class              Name

6A                  Jane,14 May 1980;Mary,4 June 1980; 
6B                  leen, 31 May 1980; Peter 6 Jan 1980;
6C                  Eillen, 19 Aug 1980; Yvwon, 28 Mar 1980;
6D                  Evan, 24 Dec 1980; Ivan, 20 Nov 1980;

Вот код, который я нашел, но как мне изменить его на то, что я хочу?

var input = Convert.ToString(datagridview1.CurrentRow.Cells[0].Value);
var resultList = Regex.Matches(input, **@".*?,(.*?),.*?;")**
    .Cast<Match>()
    .Select(arg => arg.Groups[1].Value)
    .ToList();



// bind to a combobox
comboBox1.DataSource = resultList;

1 Ответ

2 голосов
/ 11 июля 2011

Если это приложение Windows Forms, вы можете создать класс, аналогичный

class Obj {
    public string Class { get; set; }
    public string Data { get; set; }
}

затем создайте список объектов:

var list = new List<Obj>();
list.Add(new Obj() { Class = "6A", Data = "Jane,14 May 1980;Mary,4 June 1980;" });
// continue adding to the list here

, а затем

comboBox1.DataSource = list;
comboBox1.DisplayMember = "Class";

И, наконец, подключите свой comboBox1.SelectedIndexChanged к событию и захватите comboBox1.SelectedItem, примените его к Obj, и все хорошо.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...