C#的问题,怎么在List集合中筛选数据?

有一个List的泛型集合,里面已经有数据了,现在我想要按一些条件查询出筛选出里面的数据,查询的条件可能不止一条,可能有多条,该怎么做才能筛选出我要的数据?
最新回答
身虽存〃心已死゛

2024-11-07 00:04:48

方法一:Linq

ChannelList就是一个List类型的数据,IsOpen是其元素的属性

channelCount=(fromchannelinDevicesManager.Instance.CurrentDevice.ChannelList

wherechannel.IsOpen

groupchannelbychannel.ChannelID).Count();

方法二:

泛型
委托Predicate<T>

publicdelegateboolPredicate<inT>(

Tobj

方法三、

///<summary>

///筛选运送方式

///</summary>

///<paramname="list">运送方式集合</param>

///<paramname="strType">运送方式</param>

///<returns></returns>

privateList<FeeRuleDto>selectList(List<FeeRuleDto>list,stringstrType)

returnlist.FindAll(delegate(FeeRuleDtoinfo){

if(info.DeliveryType.ToString()==strType)

returntrue;

else{

returnfalse;

});

方法四、

使用List<T>获取数据库表的时候,每次用户操作都重新访问数据库,然后返回List<T>,会严重影响程序运行效率的方式,其实List<T>自带有筛选的方法,把想要的数据筛选到另一个List<T>中,不用重新访问数据库,直接筛选后绑定控件显示即可。

示例如下:

publicNumberModelcurrentmark;

publicMainFrmmainFrm;

privateList<GoodsModel>goodslist;

privateList<GoodsKindModel>goodskindlist;

privatevoidlstgoodkind_SelectedIndexChanged(objectsender,EventArgse)

try

if(lstgoodkind.SelectedValue.ToString()!="XY.Model.GoodsKindModel")

stringid=lstgoodkind.SelectedValue.ToString();

stringkname=lstgoodkind.Text;

if(kname!="全部")

List<GoodsModel>glist=goodslist.FindAll(delegate(GoodsModelp){returnp.GoodsKind==kname;});

bindgoods(dgvgoods,glist);

else

bindgoods(dgvgoods,goodslist);

catch(Exceptionex)

MessageBox.Show(ex.Message);

privatevoidbtnAdd_Click(objectsender,EventArgse)

try

stringgid=dgvgoods.Rows[dgvgoo

例如:跳过List前50条,然后取100条,可写为:

iclist_temp、iclist都为List类型

iclist_temp = iclist.Skip(50).Take(100).ToList();

取前100条,可以写为:

iclist_temp = iclist.Take(100).ToList();

ds.SelectedRows[0].Index].Cells["goodsid"].Value.ToString();

GoodsModelgoods=goodslist.Find(delegate(GoodsModelp){returnp.ID==gid;});

XY.BLL.ConsumeBll.Add(goods,currentmark,mainFrm.user);

catch(Exceptionex)

MessageBox.Show(ex.Message);

神奇花葛格

2024-11-07 00:35:05

LINQ

比如说

        List<String> list = new List<String>();
        var q = from String s in list
                where s[0] = "A" && s.Length = 4 //字符串是以A开头,并且长度为4位的
                select s;

q在就是你要的结果

甜警司

2024-11-07 03:17:21

LINQ搞起

List.Where(info=>info.Sex=="男").Where(info=>info.Age>20)

多条件就对个Where

和旋帅哥

2024-11-07 02:59:23

首先new一个新的List集合,然后用for循环,逐条读取现有的List集合中的数据,筛选出符合条件数据添加到新建的List集合中即可。

如: 

List<object> newlist = new List<object>;
for(i=0;i<oldList.Length;i++)
{
 
  if(oldList[i]符合条件)
   {
        newlist.add(oldList[i]);
   }
}
小草泠泠

2024-11-07 04:23:57

通过linq:
List<String> list = new List<String>();
var q = from String s in list
where s[0] = "A" && s.Length = 4 //字符串是以A开头,并且长度为4位的
select s;