C#有没有办法用文本框搜索所有listview项目?

时间:2013-06-25 14:37:25

标签: c# mysql database listview search

我开发了一个通过SQL CE连接填充Listview的应用程序。我已经有了插入,更新和删除功能。唯一剩下的就是搜索功能。我认为这是最简单的部分,但我现在正在寻找2天并没有找到一个很好的教程,所以我认为StackOverflow上的某个人可以帮助我。

我设法搜索了第一项(主要项目“PrincipalID”),我也想搜索子项目。我想要的就像

Principal ID    Email Address                     Subject                  Filename
193490          test@test.com                     Exec OUT (report)        q9193.xls
153130          test@test.com                     Standard mail Report     q7389.xls

我现在拥有的是我可以搜索主要数字,但我还想要搜索单词,例如,如果我在文本框中键入“test”,我将获得带有电子邮件地址的记录= “test@test.com”在顶部,或者更好的是它只会显示该记录并隐藏其余部分,然后如果文本框为空,则它会再次显示所有记录。

所以基本上我想在整个列表视图中搜索在搜索文本框中输入的字符串。

希望有人可以帮助我,

我会从内心深处感激。

提前致谢!

3 个答案:

答案 0 :(得分:0)

尝试使用此C#代码或类似内容来提取与您的字符串参数匹配的listview项。

    public void SearchInListView(ListView myListView, string searchThis) 
    {
            if (searchThis != "") 
            {
                foreach (ListViewItem lvItem in myListView.Items) 
                {
                    foreach (ListViewItem.ListViewSubItem lvSubItem in lvItem.SubItems) 
                    {
                        if (lvSubItem.Length >= 1) 
                        {
                            if (lvSubItem.ToLower().Contains(searchThis.ToLower())) 
                                //Mark this listview item in some way (e.g., change back color) or collect and return it
                            else 
                                //Mark this listview in a different way
                         }    
                    }
                 }
             }
    }

答案 1 :(得分:0)

您可以使用TextBox的TextChanged事件,如果您搜索List,则只能将您要搜索的Record绑定到Grid。

因此,您可以在列表中搜索特定记录。

答案 2 :(得分:0)

你必须解雇两个问题.... 如果输入Textbox1.Text.IsNumber,则按原则id搜索 否则通过电子邮件搜索 在查询中使用 也许是它的工作