C# 从一个list中取出某一字段并去重生成一个新的list

public class AppointmentsDto
    {
        /// <summary>
        /// 资源ID
        /// </summary>
        public string ResourceID { get; set; }
        /// <summary>
        /// 部门ID
        /// </summary>
        public string DeptID { get; set; }
        /// <summary>
        /// 部门名称
        /// </summary>
        public string DeptName { get; set; }
    }
public class AppointmentsResourceDto
    {
        /// <summary>
        /// 资源ID
        /// </summary>
        public string ResourceID { get; set; }
    }

方法一:使用LinQ先对 AppointmentsDto对象列表中的ResourceID字段去重,然后转成AppointmentsResourceDto列表对象。

//查询列表
List<AppointmentsDto> lst = GetListByTable();
//获取AppointmentsResourceDto对象列表
List<AppointmentsResourceDto> obj = from e in lst.Select(o => o.ResourceID).Distinct() select new AppointmentsResourceDto { ResourceID = e };

 方法二:

//查询列表
List<AppointmentsDto> lst = GetListByTable();
//取得AppointmentsResourceDto对象列表
List<AppointmentsResourceDto> obj = lst.Select(o => o.ResourceID).Distinct().ToList().ConvertAll<AppointmentsResourceDto>(o => new AppointmentsResourceDto { ResourceID = o.ToString() });

这种方法一般可以用在日程,约会。例如:SchedulerControl控件的数据源。

步骤:用过一条SQL查出一个列表,作为SchedulerStorage的Appointments.DataSource。
然后从该列表中过滤去重取得一个新的列表作为SchedulerStorage的Resources.DataSource。

 

  • 6
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值