我的部分程序具有普通搜索功能,用户在文本框中输入数据,它将根据用户输入的内容显示结果。这是我的代码:
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,很快。那么有一个简单的代码来解决这个问题吗?
答案 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());
}
}
}