using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;

namespace Common.Unit
{
    public static class ListHelper
    {
        /// <summary>
        /// 将List转换成String
        /// </summary>
        /// <param name="list">List对象</param>
        /// <returns></returns>
        public static string SeperateToString(this IEnumerable<int> list)
        {
            return SeperateToString(list, ",");
        }

        /// <summary>
        /// 将List转换成String
        /// </summary>
        /// <param name="list">List对象</param>
        /// <param name="seperate">分隔符</param>
        /// <returns></returns>
        public static string SeperateToString(this IEnumerable<int> list, string seperate)
        {
            string str = "";
            )
                return str;
            foreach (int i in list)
            {
                str += seperate + i;
            }
            return str.Substring(seperate.Length);
        }

        /// <summary>
        /// 将List转换成String
        /// </summary>
        /// <param name="list">List对象</param>
        /// <returns></returns>
        public static string SeperateToString(this IEnumerable<string> list)
        {
            return SeperateToString(list, ",");
        }

        /// <summary>
        /// 将List转换成String
        /// </summary>
        /// <param name="list">List对象</param>
        /// <returns></returns>
        public static string SeperateToString(this IEnumerable<string> list, bool removeEmpty)
        {
            return SeperateToString(list, ",", removeEmpty);
        }

        /// <summary>
        /// 将List转换成String
        /// </summary>
        /// <param name="list">List对象</param>
        /// <param name="seperate">分隔符</param>
        /// <returns></returns>
        public static string SeperateToString(this IEnumerable<string> list, string seperate)
        {
            return SeperateToString(list, seperate, false);
        }

        /// <summary>
        /// 将List转换成String
        /// </summary>
        /// <param name="list">List对象</param>
        /// <param name="seperate">分隔符</param>
        /// <param name="removeEmpty">移除空字符</param>
        /// <returns></returns>
        public static string SeperateToString(this IEnumerable<string> list, string seperate, bool removeEmpty)
        {
            string str = "";
            )
                return str;
            foreach (string s in list)
            {
                if (removeEmpty && string.IsNullOrEmpty(s))
                    continue;
                str += seperate + s;
            }
            )
                str = str.Substring(seperate.Length);
            return str;
        }
        /// <summary>
        /// 扩展distinct 方法 调用方式lst = lst.Distinct((x, y) => x.ID==y.ID ).ToList();
        /// </summary>
        /// <typeparam name="TSource"></typeparam>
        /// <param name="list"></param>
        /// <param name="dele"></param>
        /// <returns></returns>
        public static IEnumerable<TSource> Distinct<TSource>(this IEnumerable<TSource> list, EqualsComparer<TSource> dele)
        {
            return list.Distinct(new Compare<TSource>(dele));
        }

        /// <summary>
        /// 扩展distinct 方法 调用方式 lst = lst.Distinct(p => p.ID).ToList();
        /// </summary>
        /// <typeparam name="T"></typeparam>
        /// <typeparam name="V"></typeparam>
        /// <param name="source"></param>
        /// <param name="keySelector"></param>
        /// <returns></returns>
        public static IEnumerable<T> Distinct<T, V>(this IEnumerable<T> source, Func<T, V> keySelector)
        {
            return source.Distinct(new CommonEqualityComparer<T, V>(keySelector));
        }  

        static void test()
        {
            List<int> list = new List<int>();
            list.Add();
            list.Add();
            list.Add();
            Console.WriteLine(list.SeperateToString(","));

            List<string> list2 = new List<string>();
            list2.Add(");
            list2.Add(");
            list2.Add(");
            Console.WriteLine(list2.SeperateToString(",", false));
        }
    }

    #region 实现Distinct IEqualityComparer 接口
    public delegate bool EqualsComparer<T>(T x, T y);
    public class Compare<T> : IEqualityComparer<T>
    {
        private EqualsComparer<T> _equalsComparer;

        public Compare(EqualsComparer<T> equalsComparer)
        {
            this._equalsComparer = equalsComparer;
        }

        public bool Equals(T x, T y)
        {
            if (null != this._equalsComparer)
                return this._equalsComparer(x, y);
            else
                return false;
        }
        public int GetHashCode(T obj)
        {
            return obj.ToString().GetHashCode();
        }
    }

    public class CommonEqualityComparer<T, V> : IEqualityComparer<T>
    {
        private Func<T, V> keySelector;

        public CommonEqualityComparer(Func<T, V> keySelector)
        {
            this.keySelector = keySelector;
        }

        public bool Equals(T x, T y)
        {
            return EqualityComparer<V>.Default.Equals(keySelector(x), keySelector(y));
        }

        public int GetHashCode(T obj)
        {
            return EqualityComparer<V>.Default.GetHashCode(keySelector(obj));
        }
    }
#endregion
}

C# List 扩展排序的更多相关文章

  1. hive 排序和聚集

    1.order by 是对数据进行全排序,属于标准排序语句 order by 会对输入做全局排序,因此只有一个reducer(多个reducer无法保证全局有序)只有一个reducer,会导致当输入规 ...

  2. java 字符串排序

    http://bbs.csdn.net/topics/280032929 大可不需要那样复杂了!(一)如果要排序的为字符串,如:String sortStr = "ACDFE";  ...

  3. javascript table排序之jquery.tablesorter.js

    table排序 jquery.tablesorter.js 一.Demo下载地址: 1.tablesorter.js下载地址: http://download.csdn.net/detail/zhan ...

  4. Guava中强大的排序器Ordering使用

    一 创建排序器 排序器:可以用来为构建复杂的比较器,以完成集合排序的功能: 本质上来说,Ordering 实例无非就是一个特殊的Comparator 实例. Ordering把很多基于Comparat ...

  5. ORA 各种oraclesql错误

    ORA-00001: 违反唯一约束条件 (.) ORA-00017: 请求会话以设置跟踪事件 ORA-00018: 超出最大会话数 ORA-00019: 超出最大会话许可数 ORA-00020: 超出 ...

  6. oracle 错误代码大全

    oracle错误代码大全(超详细)   ORA-00001: 违反唯一约束条件 (.) ORA-00017: 请求会话以设置跟踪事件 ORA-00018: 超出最大会话数 ORA-00019: 超出最 ...

  7. SQL错误码

    ///////////////////////////////////////////////////////////////ORA-00001: 违反唯一约束条件 (.)ORA-00017: 请求会 ...

  8. oracle错误码

    ORA-00001: 违反唯一约束条件 (.) ORA-00017: 请求会话以设置跟踪事件 ORA-00018: 超出最大会话数 ORA-00019: 超出最大会话许可数 ORA-00020: 超出 ...

  9. Oracle 错误代码

    ORA-00001: 违反唯一约束条件 (.) ORA-00017: 请求会话以设置跟踪事件 ORA-00018: 超出最大会话数 ORA-00019: 超出最大会话许可数 ORA-00020: 超出 ...

随机推荐

  1. lucene 总结收集(url)

    1.倒排索引结构 2.lucene自定义评分域 3.Lucene系列-FieldCache 4.Lucene系列-facet | IT瘾 5.lucene4.7 之排序 6.lucene排序---相关 ...

  2. sql server 自定义split 标值函数

    自定义一个函数,分隔一个以分隔符的隔开字符串,例如把'1,3,5,7,9' 变成 数字1 3 5 7 9的结果集. 自定义标值函数: ),)) )) --实现split功能 的函数 as begin ...

  3. python修炼6

    文件操作 注:不能把open语句放在try块里,因为当打开文件出现异常时,文件对象file_object无法执行close()方法. 1.打开文件 (相当于桌面的快捷方式)f=open(文件名,模式默 ...

  4. MyBatis 异常 集锦

    异常1.使用映射器 (还没有使用Spring) 异常信息摘要: org.apache.ibatis.binding.BindingException: Type interface com.jege. ...

  5. php入门 数据类型 运算符 语言结构语句 函数 类与面向对象

    php PHP-enabled web pages are treated just like regular HTML pages and you can create and edit them ...

  6. WI-FI: connection through CLI

    First, ensure that the computer/sbc has WI-FI parts. install wpa_supplicant, edit /etc/wpa_supplican ...

  7. SQL中判断字符串中包含字符的方法

    通过2个函数CHARINDEX和PATINDEX以及通配符的灵活使用 函数:CHARINDEX和PATINDEX CHARINDEX:查某字符(串)是否包含在其他字符串中,返回字符串中指定表达式的起始 ...

  8. 《JavaScript高级程序设计》读书笔记 ---Array 类型

    除了Object 之外,Array 类型恐怕是ECMAScript 中最常用的类型了.而且,ECMAScript 中的数组与其他多数语言中的数组有着相当大的区别.虽然ECMAScript 数组与其他语 ...

  9. Hibernate5-课程笔记2

    单表的增删改查操作: (1)定义获取Session和SessionFactory的工具类: package com.tongji.utils; import org.hibernate.Session ...

  10. Linux下安装awstats日志统计分析

    1. 下载安装 cd /data/software wget http://prdownloads.sourceforge.net/awstats/awstats-7.0-1.noarch.rpm 2 ...