c#使用条件从datagridview填充组合框

时间:2016-07-13 08:48:01

标签: c# datagridview combobox

在我的项目中,我正在使用像这样的数据库

package com.activitytest2;

import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.view.Menu;
import android.view.MenuItem;
import android.view.View;
import android.view.Window;
import android.widget.Button;
import android.widget.Toast;

public class FirstActivity extends AppCompatActivity {

@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    //1.   getActionBar().hide();
    //2.   requestWindowFeature(Window.FEATURE_NO_TITLE);
    setContentView(R.layout.first_layout);
    Button button1 = (Button) findViewById(R.id.button_1);
    button1.setOnClickListener(new View.OnClickListener() {
        @Override
        public void onClick(View view) {
            Toast.makeText(FirstActivity.this,"You clicked button 1",Toast.LENGTH_SHORT).show();
        }
    });
}

}

layout.xml

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:orientation="vertical" android:layout_width="match_parent"
    android:layout_height="match_parent">
    <Button
        android:id="@+id/button_1"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:text="button 1"/>
</LinearLayout>

AndroidManifest.xml

<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
    package="com.activitytest2">

    <application
        android:allowBackup="true"
        android:icon="@mipmap/ic_launcher"
        android:label="@string/app_name"
        android:supportsRtl="true"
        android:theme="@style/AppTheme">
        <activity android:name=".FirstActivity">
            <intent-filter>
                <action android:name="android.intent.action.MAIN" />

                <category android:name="android.intent.category.LAUNCHER" />
            </intent-filter>
        </activity>
    </application>


styles.xml

<resources>

    <!-- Base application theme. -->
    <style name="AppTheme" parent="Theme.AppCompat.Light.DarkActionBar">
        <!-- Customize your theme here. -->
        <item name="colorPrimary">@color/colorPrimary</item>
        <item name="colorPrimaryDark">@color/colorPrimaryDark</item>
        <item name="colorAccent">@color/colorAccent</item>
    </style>
 </resources>

我正在使用这段代码用所有名称填充组合框:

ID | Name   | Function
1  | John   | CH
2  | Maria  | CD
3  | Nikita | CH
4  | Carin  | CH

现在我想用一些名字填充组合框,使用这样的公式:

带有CH功能的每个名称的

  - &gt;在MyCombobox中添加该名称

我坚持了,你能帮助我吗?

2 个答案:

答案 0 :(得分:1)

让我们做对了!

DataTable专为数据存储而设计 DataGridViewComboBox专为数据代表而设计。

将数据放入DataTable

DataTable dt = new DataTable("Person");

dt.Columns.Add("ID", typeof(string));
dt.Columns.Add("Name", typeof(string));
dt.Columns.Add("Function", typeof(string));

dt.Rows.Add("1", "John", "CH");
dt.Rows.Add("2", "Maria", "CD");
dt.Rows.Add("3", "Nikita", "CH");
dt.Rows.Add("4", "Carin", "CH");

将原始数据绑定到DataGridView

dataGridView.DataSource = dt;

现在我们需要将过滤后的数据绑定到ComboBox

DataView view = dt.AsDataView();
view.RowFilter = "Function = 'CH'";
comboBox.DisplayMember = "Name";
comboBox.DataSource = view;

就绪!

现在,如果您更改DataGridView中的数据,这些更改将自动显示在ComboBox

例如,将Function列值从CH更改为CD John,并从ComboBox消失。

此外,您可以动态更改过滤条件。

指定

view.RowFilter = "Function = 'CD'";

瞧! ComboBox现在显示其他名称。

答案 1 :(得分:0)

  

试试这个

MyComboBox.Items.Clear();
foreach (DataGridViewRow row in dataGridView.Rows)
{
    if (row.Cells["Function"].Value!=null && row.Cells["Function"].Value.Equals("CH"))
    MyComboBox.Items.Add(row.Cells["Name"].Value.ToString());
}