在我的项目中,我正在使用像这样的数据库
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中添加该名称
我坚持了,你能帮助我吗?
答案 0 :(得分:1)
让我们做对了!
DataTable
专为数据存储而设计
DataGridView
和ComboBox
专为数据代表而设计。
将数据放入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());
}