Warning: file_get_contents(/data/phpspider/zhask/data//catemap/2/csharp/334.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
C# 如何更改代码以检索datagridview中的特定列?_C#_Winforms_Datagridview - Fatal编程技术网

C# 如何更改代码以检索datagridview中的特定列?

C# 如何更改代码以检索datagridview中的特定列?,c#,winforms,datagridview,C#,Winforms,Datagridview,我在datagridview中有一个数据列表。例如,一列被命名为Class(每行有一个不同的值,请参见下文),是否可能有一个组合框,其中包含组合框中所有可能的记录类值*它应该有一个6A、6B、6C的列表 如果以后将更多类添加到数据库中(示例6D),则这些类也应位于组合框中* datagridview的视图 Class Name 6A Jane,14 May 1980;Mary,4 June 1980; 6B

我在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;
var input=Convert.ToString(datagridview1.CurrentRow.Cells[0].Value);
var resultList=Regex.Matches(输入,***@“*?,(.*?,.*?;”)**
.Cast()
.Select(arg=>arg.Groups[1].Value)
.ToList();
//绑定到组合框
comboBox1.DataSource=resultList;

如果这是一个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

最后,将你的
组合框1.SelectedIndexChanged
挂接到一个事件上,然后抓取
组合框1.SelectedItem
,将其投射到Obj,你就很好了。

任何人都知道如何更改,我在这方面非常需要帮助!你能检查一下resultList变量并告诉我们它是否得到了正确的值吗?但是我没有使用硬编码,我有一个数据源,我将如何与你的代码相结合?@cutexxxpies:你将用你用来查询的任何方法(比如从数据源)替换硬编码列表元素的代码。你最初的问题并不清楚这就是问题所在。您可能需要清楚地识别原始问题中的两个问题。@IAstract,基本上我有一个数据库绑定到datagridview,这类似于我在问题中显示的内容,但是,我希望该类显示在组合框中,但不是以硬编码的方式显示,因为如果添加了更多类,组合框将自动更新以获得,现在的问题是Sergei Z给出的代码,关于你所说的内容,我该如何改变它me@cutexxxpies:每当您将数据库“绑定”到datagridview时,为什么不将组合框也绑定到那里?此时,唯一需要做的就是在数据源中将
comboBox1.DisplayMember
设置为正确的字段。@Sergei Z可以告诉我你的意思吗?因为在绑定组合框之前,我从未尝试过使用它……所以您的意思是这个comboBox1.DisplayMember=“Class”//您在这里声明的这个类是数据库字段名??
comboBox1.DataSource = list;
comboBox1.DisplayMember = "Class";