C#;麻烦好心人:如何实现dataGridView的筛选?
从txt导入到dataGridView中已经实现用的datatable。现在的问题是:例如:002001张三002003李四001009王五007112赵六002779如...
从txt导入到dataGridView中已经实现用的datatable。现在的问题是:
例如:002001 张三
002003 李四
001009 王五
007112 赵六
002779 如花
我想实现在textbox中输入2然后dataGridView中只显示第一 二 五行,即002开头的。因为已经导入完毕,我希望尽量不要动导入部分,而是直接筛选将不需要的隐藏,可行吗?若可行如何实现?若不可行有什么方法呢?
之前得到好心人提示用select:
DataTable tb = new DataTable();
DataColumn cl = new DataColumn();
cl.ColumnName = "userName";
cl.DataType = typeof(string);
tb.Columns.Add(cl);
for (int i = 0; i < 20; i++)
{
DataRow row = tb.NewRow();
if (i % 2 == 0)
{
row["userName"] = "zl" + i;
}
else
{
row["userName"] = "002" + i;
}
tb.Rows.Add(row);
}
DataRow[] rows= tb.Select("userName like '002%'");
我试了半天,没达到预期效果,求解答! 展开
例如:002001 张三
002003 李四
001009 王五
007112 赵六
002779 如花
我想实现在textbox中输入2然后dataGridView中只显示第一 二 五行,即002开头的。因为已经导入完毕,我希望尽量不要动导入部分,而是直接筛选将不需要的隐藏,可行吗?若可行如何实现?若不可行有什么方法呢?
之前得到好心人提示用select:
DataTable tb = new DataTable();
DataColumn cl = new DataColumn();
cl.ColumnName = "userName";
cl.DataType = typeof(string);
tb.Columns.Add(cl);
for (int i = 0; i < 20; i++)
{
DataRow row = tb.NewRow();
if (i % 2 == 0)
{
row["userName"] = "zl" + i;
}
else
{
row["userName"] = "002" + i;
}
tb.Rows.Add(row);
}
DataRow[] rows= tb.Select("userName like '002%'");
我试了半天,没达到预期效果,求解答! 展开
展开全部
在你的筛选按钮里面
假如现在你的表格的datasource对应了一个datatable dt
那现在你定义一个dataview dv=new dataview(dt)
然后 dv.filter=string.format("列明 like '%{0}%'",textbox的值);
datagridview1.datasource=dv;
假如现在你的表格的datasource对应了一个datatable dt
那现在你定义一个dataview dv=new dataview(dt)
然后 dv.filter=string.format("列明 like '%{0}%'",textbox的值);
datagridview1.datasource=dv;
追问
我试了下可行,只是还不完全是我想要的他是002XXX或者0023XX,即筛选的是特定第二位,或第二位和第三位,是不是在 '%{0}%'中作修改呢?怎么改?网上这块东西不多,麻烦您了!
追答
%号代表若干字符
如果是002开头
string.format("列明 like '{0}%'","002");
下面的写法是等于
string.format("列明 = '{0}'","002");
本回答被提问者采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询