我在datagridview中有一个数据列表。例如,一列名为Class(每行有不同的值,见下文),是否有可能有一个组合框,它包含组合框中的所有可能的记录类值? * 应该有一个6A,6B,6C的列表 如果稍后将更多类添加到数据库(示例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;
答案 0 :(得分:2)
如果这是一个Windows窗体应用程序,那么您可以创建一个类,类似于
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,你很好。