0

我开发了一个通过 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”在顶部,或者更好的是它只会显示该记录并隐藏其余记录,然后如果文本框为空,它会再次显示所有记录。

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

希望有人可以帮助我,

我会从心底感激它。

提前致谢!

4

3 回答 3

0

您可以使用 TextBox 的 TextChanged 事件,如果您搜索列表,则只能将您正在搜索的记录绑定到网格。

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

于 2013-06-25T14:54:37.137 回答
0

尝试使用此 C# 代码或类似的东西来提取与您的字符串参数匹配的列表视图项。

    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
                         }    
                    }
                 }
             }
    }
于 2013-06-25T14:53:06.263 回答
0

你必须触发两个查询....如果输入 Textbox1.Text.IsNumber 然后按原则 id 搜索,否则通过电子邮件搜索,如查询中的使用可能是它的工作

于 2013-06-25T14:56:31.223 回答