C# List 扩展排序
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 扩展排序的更多相关文章
- hive 排序和聚集
1.order by 是对数据进行全排序,属于标准排序语句 order by 会对输入做全局排序,因此只有一个reducer(多个reducer无法保证全局有序)只有一个reducer,会导致当输入规 ...
- java 字符串排序
http://bbs.csdn.net/topics/280032929 大可不需要那样复杂了!(一)如果要排序的为字符串,如:String sortStr = "ACDFE"; ...
- javascript table排序之jquery.tablesorter.js
table排序 jquery.tablesorter.js 一.Demo下载地址: 1.tablesorter.js下载地址: http://download.csdn.net/detail/zhan ...
- Guava中强大的排序器Ordering使用
一 创建排序器 排序器:可以用来为构建复杂的比较器,以完成集合排序的功能: 本质上来说,Ordering 实例无非就是一个特殊的Comparator 实例. Ordering把很多基于Comparat ...
- ORA 各种oraclesql错误
ORA-00001: 违反唯一约束条件 (.) ORA-00017: 请求会话以设置跟踪事件 ORA-00018: 超出最大会话数 ORA-00019: 超出最大会话许可数 ORA-00020: 超出 ...
- oracle 错误代码大全
oracle错误代码大全(超详细) ORA-00001: 违反唯一约束条件 (.) ORA-00017: 请求会话以设置跟踪事件 ORA-00018: 超出最大会话数 ORA-00019: 超出最 ...
- SQL错误码
///////////////////////////////////////////////////////////////ORA-00001: 违反唯一约束条件 (.)ORA-00017: 请求会 ...
- oracle错误码
ORA-00001: 违反唯一约束条件 (.) ORA-00017: 请求会话以设置跟踪事件 ORA-00018: 超出最大会话数 ORA-00019: 超出最大会话许可数 ORA-00020: 超出 ...
- Oracle 错误代码
ORA-00001: 违反唯一约束条件 (.) ORA-00017: 请求会话以设置跟踪事件 ORA-00018: 超出最大会话数 ORA-00019: 超出最大会话许可数 ORA-00020: 超出 ...
随机推荐
- lucene 总结收集(url)
1.倒排索引结构 2.lucene自定义评分域 3.Lucene系列-FieldCache 4.Lucene系列-facet | IT瘾 5.lucene4.7 之排序 6.lucene排序---相关 ...
- sql server 自定义split 标值函数
自定义一个函数,分隔一个以分隔符的隔开字符串,例如把'1,3,5,7,9' 变成 数字1 3 5 7 9的结果集. 自定义标值函数: ),)) )) --实现split功能 的函数 as begin ...
- python修炼6
文件操作 注:不能把open语句放在try块里,因为当打开文件出现异常时,文件对象file_object无法执行close()方法. 1.打开文件 (相当于桌面的快捷方式)f=open(文件名,模式默 ...
- MyBatis 异常 集锦
异常1.使用映射器 (还没有使用Spring) 异常信息摘要: org.apache.ibatis.binding.BindingException: Type interface com.jege. ...
- php入门 数据类型 运算符 语言结构语句 函数 类与面向对象
php PHP-enabled web pages are treated just like regular HTML pages and you can create and edit them ...
- WI-FI: connection through CLI
First, ensure that the computer/sbc has WI-FI parts. install wpa_supplicant, edit /etc/wpa_supplican ...
- SQL中判断字符串中包含字符的方法
通过2个函数CHARINDEX和PATINDEX以及通配符的灵活使用 函数:CHARINDEX和PATINDEX CHARINDEX:查某字符(串)是否包含在其他字符串中,返回字符串中指定表达式的起始 ...
- 《JavaScript高级程序设计》读书笔记 ---Array 类型
除了Object 之外,Array 类型恐怕是ECMAScript 中最常用的类型了.而且,ECMAScript 中的数组与其他多数语言中的数组有着相当大的区别.虽然ECMAScript 数组与其他语 ...
- Hibernate5-课程笔记2
单表的增删改查操作: (1)定义获取Session和SessionFactory的工具类: package com.tongji.utils; import org.hibernate.Session ...
- Linux下安装awstats日志统计分析
1. 下载安装 cd /data/software wget http://prdownloads.sourceforge.net/awstats/awstats-7.0-1.noarch.rpm 2 ...