有没有简单的方法可以将文本框上的响应式搜索结果发送到数据网格?

时间:2017-05-18 15:54:38

标签: c# winforms

我的部分程序具有普通搜索功能,用户在文本框中输入数据,它将根据用户输入的内容显示结果。这是我的代码:

private void textBox1_TextChanged(object sender, EventArgs e)
{
    Boolean find = false;
    if (cmbSearchFilter.Text == "Product Name")
    {
        int row = 0;
        string line, search;
        string[] strArray = new string[6];
        dataGridView1.Rows.Clear();
        dataGridView1.ColumnCount = 7;
        dataGridView1.Columns[0].Name = "Nugget ID";
        dataGridView1.Columns[1].Name = "Nugget Name";
        dataGridView1.Columns[2].Name = "Nugget Description";
        dataGridView1.Columns[3].Name = "Nugget Ingredient";
        dataGridView1.Columns[4].Name = "Nugget Stock";
        dataGridView1.Columns[5].Name = "Nugget Price";
        F = new FileStream("Nugget.txt", FileMode.Open, FileAccess.Read);
        R = new StreamReader(F);
        search = txtSearch.Text;
        while ((line = R.ReadLine()) != null)
        {
            strArray = line.Split(new string[] { "#" }, StringSplitOptions.None);
            if (search.Equals(strArray[1]))
            {
                find = true;
                dataGridView1.Rows.Add();
                String[] s = line.Split('#');
                for (int i = 0; i <= s.Count() - 1; i++)
                {
                    dataGridView1[i, row].Value = s[i];
                }
                row++;
            }
        }
        R.Close();
        F.Close();
    }
}

我根据用户在组合框中选择的内容使用IF条件。因此,这种情况的代码和问题没有问题。

回到主要问题,我想让搜索结果响应,例如,如果我在文本文件中提供了这些数据:

Chicken Nugget
Cheese Nugget
Tofu Nugget
Vegetable Nugget

首先,当用户输入&#39; C&#39;单词,dgv上的结果将显示数据Chicken Nugget和Cheese Nugget。其次,在打字时,&#39; h&#39; (在&#39; C&#39;之后),结果将显示Chicken Nugget和Cheese Nugget(再次)。第三,当键入&#39; e&#39;(&#39; Ch&#39;)之后,结果将只显示Cheese Nugget,很快。那么有一个简单的代码来解决这个问题吗?

2 个答案:

答案 0 :(得分:0)

未声明F和R. 对于在文本框中键入的每个字符,您可以重新创建所有datagridview列,打开并读取文件,然后手动填写dgv。我可能会在类级别创建一个字符串列表来保存文件信息,如果它是空的,则只填充第一次,然后使用该列表作为dgv的数据源。

答案 1 :(得分:0)

如上所述,您可以在表单加载时执行一次,而不是每次按键加载网格。此代码可以移动到表单加载事件:

private void LoadGrid()
{
    int row = 0;
    string line;
    string[] strArray = new string[6];
    dataGridView1.Rows.Clear();
    dataGridView1.ColumnCount = 7;
    dataGridView1.Columns[0].Name = "Nugget ID";
    dataGridView1.Columns[1].Name = "Nugget Name";
    dataGridView1.Columns[2].Name = "Nugget Description";
    dataGridView1.Columns[3].Name = "Nugget Ingredient";
    dataGridView1.Columns[4].Name = "Nugget Stock";
    dataGridView1.Columns[5].Name = "Nugget Price";
    FileStream F = new FileStream("Nugget.txt", FileMode.Open, FileAccess.Read);
    StreamReader R = new StreamReader(F);

    while ((line = R.ReadLine()) != null)
    {
        strArray = line.Split(new string[] { "#" }, StringSplitOptions.None);

        dataGridView1.Rows.Add();
        String[] s = line.Split('#');
        for (int i = 0; i <= s.Count() - 1; i++)
        {
            dataGridView1[i, row].Value = s[i];
        }
    }

    R.Close();
    F.Close();
}

要查找文本的一部分,您可以使用字符串&#34;包含&#34;方法。可以将要比较的每个字符串转换为小写,以使比较大小写不敏感。您可以使用DataGridViewRow.Visible属性仅显示与您的搜索匹配的行。

private void textBox1_TextChanged(object sender, EventArgs e)
{
    string search = txtSearch.Text;

    foreach (DataGridViewRow row in dataGridView1.Rows)
    {
        if (row.Cells["Nugget Name"].Value != null)
        {
            string productName = row.Cells["Nugget Name"].Value.ToString();
            row.Visible = productName.ToLower().Contains(search.ToLower());
        }
    }
}