C#中有没有类似于SQL中的%那种通配符, 怎么在C#中实现模糊搜索(不用数据库) 100

知道的发923722039@qq.com... 知道的发923722039@qq.com 展开
 我来答
那远方的天001
2018-05-12
知道答主
回答量:1
采纳率:0%
帮助的人:868
展开全部

1.用一个List<string> listOnit存放初始化数据,用一个List<string> listNew存放输入key之后,返回的数据。

2.用上面的listOnit初始化ComboBox数据源进行绑定。

3.在TextUpdate方法内部,添加实现方法。

首先进入方法,先清除ComboBox的内容,然后将输入的内容去listOnit初始化的数据中比对,找出对应数据,然后放入listNew存放数据,最后将listNew数据重新赋值给ComboBox。

后台代码实现:

using System;

using System.Collections.Generic;

using System.ComponentModel;

using System.Data;

using System.Drawing;

using System.Linq;

using System.Text;

using System.Windows.Forms;

namespace TimerDemo

{

public partial class Form2 : Form

{

//初始化绑定默认关键词(此数据源可以从数据库取)

List<string> listOnit = new List<string>();

//输入key之后,返回的关键词

List<string> listNew = new List<string>();

public Form2()

{

InitializeComponent();

}

private void Form2_Load(object sender, EventArgs e)

{

//调用绑定

BindComboBox();

}

/// <summary>

/// 绑定ComboBox

/// </summary>

private void BindComboBox()

{

listOnit.Add("张三");

listOnit.Add("张思");

listOnit.Add("张五");

listOnit.Add("王五");

listOnit.Add("刘宇");

listOnit.Add("马六");

listOnit.Add("孙楠");

listOnit.Add("那英");

listOnit.Add("刘欢");

/*

* 1.注意用Item.Add(obj)或者Item.AddRange(obj)方式添加

* 2.如果用DataSource绑定,后面再进行绑定是不行的,即便是Add或者Clear也不行

*/

this.comboBox1.Items.AddRange(listOnit.ToArray());

}

private void comboBox1_TextChanged(object sender, EventArgs e)

{

/*

* 不能用TextChanged操作,当this.comboBox1.DroppedDown为True时,选择项上下键有冲突

*/

}

private void comboBox1_TextUpdate(object sender, EventArgs e)

{

//清空combobox

this.comboBox1.Items.Clear();

//清空listNew

listNew.Clear();

//遍历全部备查数据

foreach (var item in listOnit)

{

if (item.Contains(this.comboBox1.Text))

{

//符合,插入ListNew

listNew.Add(item);

}

}

//combobox添加已经查到的关键词

this.comboBox1.Items.AddRange(listNew.ToArray());

//设置光标位置,否则光标位置始终保持在第一列,造成输入关键词的倒序排列

this.comboBox1.SelectionStart = this.comboBox1.Text.Length;

//保持鼠标指针原来状态,有时候鼠标指针会被下拉框覆盖,所以要进行一次设置。

Cursor = Cursors.Default;

//自动弹出下拉框

this.comboBox1.DroppedDown = true;

}

}

}

实现效果截图:

从左到右模糊查询:(例如输入:张)

可以得出正常模糊查询的结果。

从左到右模糊查询(例如输入:三)

实现过程中的问题:

1.绑定数据一开始用的DataSource方式,但是写到下面重新给ComboBox设置数据源的时候,报错:不能为已经设置DataSource的combobox赋值。

解决方式:将赋值方式改为:Item.Add(obj)或者Item.AddRange(obj)方式

2.下拉框的内容一直在增加

解决方式:当文本框文本改变时,清空下拉框的内容,然后再添加数据。

3.输入文本改变时,没有自动弹出下拉框显示已经查询好的数据。

解决方式:设置comboBox的DroppedDown 属性为True。

4.ComboBox文本框改变事件一开始选择用的是TextChanged事件,但是当在界面用 上 下键盘选择时,出现bug,不能进行选择。

解决方式:将文本框改变事件换为TextUpdate事件,然后添加实现方法。

5.当在ComboBox输入内容时,内容文本是倒序输出的,光标位置始终在最前面。

解决方式:设置光标的显示位置,this.comboBox1.SelectionStart = this.comboBox1.Text.Length;

6.输入内容改变时,用鼠标选择下拉列表项的时候,鼠标指针消失,被下拉框覆盖掉。

解决方式:设置鼠标状态为一开始的默认状态,Cursor = Cursors.Default;

疍壳里de小宇宙
2012-12-25
知道答主
回答量:4
采纳率:0%
帮助的人:6023
展开全部
正则表达式比较方便,也可以自己写方法也行,根据自己的需求定吧
string xml = "asdf<!--asdfsdf-->asdf";
int count = Regex.Matches(xml, "-->").Count;
for (int i = 0; i < count; i++)
{
string remarks = xml.Substring(xml.LastIndexOf("<!--"), (xml.LastIndexOf("-->") + 3) - xml.LastIndexOf("<!--"));
xml = xml.Replace(remarks, "");
}

看看str1里有没有str2,返回bool值 用indexOf...

这是我以前做的移除一个字符串中包含的另一个字符串,希望能帮的到LZ。
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
你明远f
2012-12-25 · TA获得超过327个赞
知道小有建树答主
回答量:185
采纳率:50%
帮助的人:65.4万
展开全部
string sql = "select * from Jobs where job_desc like '%a%'";
string sql = "select * from Jobs where job_desc like '%'+@parametar+'%'";
string sql = "select * from Jobs where job_desc like '%'"+str+"'%'";//str为变量名
其他的我也不知道,你看看只要没有要求,实现功能就好了啊
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
军飞双0l
2012-12-25 · TA获得超过278个赞
知道小有建树答主
回答量:238
采纳率:50%
帮助的人:65.9万
展开全部
正则表达式
是一种验证规则,比如要输入电话号码,正则表达式可以帮你判断用户输入的是否是电话号码
比如^王[\u4e00-\u9fa5]+$ 就是匹配姓王的名字
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
我怀念的ren
2012-12-25 · TA获得超过116个赞
知道小有建树答主
回答量:210
采纳率:0%
帮助的人:127万
展开全部
在一个字符串中查询吗,有很多方法,可以用正则、是否包含、拉姆达表达式等
追问
具体点啊,我不知道怎么用正则表达式啊,这个我也百度到了
追答
你想要干什么,或者实现什么功能
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 更多回答(9)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式