是否有任何简单的LINQ表达式将我的整个List<string>集合项连接到具有分隔符字符的单个字符串?
如果集合是自定义对象而不是字符串呢?假设我需要连接object。name。
是否有任何简单的LINQ表达式将我的整个List<string>集合项连接到具有分隔符字符的单个字符串?
如果集合是自定义对象而不是字符串呢?假设我需要连接object。name。
当前回答
注意:这个答案不使用LINQ来生成连接的字符串。使用LINQ将枚举对象转换为带分隔符的字符串会导致严重的性能问题
现代。net(从。net 4开始)
这适用于数组、列表或任何实现IEnumerable类型:
string.Join(delimiter, enumerable);
这是一个可枚举的自定义对象:
string.Join(delimiter, enumerable.Select(i => i.Boo));
旧的。net(在。net 4之前)
这是一个字符串数组:
string.Join(delimiter, array);
这是针对List<string>:
string.Join(delimiter, list.ToArray());
这是一个自定义对象列表:
string.Join(delimiter, list.Select(i => i.Boo).ToArray());
其他回答
List<string> strings = new List<string>() { "ABC", "DEF", "GHI" };
string s = strings.Aggregate((a, b) => a + ',' + b);
我认为如果你在扩展方法中定义逻辑,代码将更易于阅读:
public static class EnumerableExtensions {
public static string Join<T>(this IEnumerable<T> self, string separator) {
return String.Join(separator, self.Select(e => e.ToString()).ToArray());
}
}
public class Person {
public string FirstName { get; set; }
public string LastName { get; set; }
public override string ToString() {
return string.Format("{0} {1}", FirstName, LastName);
}
}
// ...
List<Person> people = new List<Person>();
// ...
string fullNames = people.Join(", ");
string lastNames = people.Select(p => p.LastName).Join(", ");
我已经使用LINQ做到了这一点:
var oCSP = (from P in db.Products select new { P.ProductName });
string joinedString = string.Join(",", oCSP.Select(p => p.ProductName));
你可以简单地使用:
List<string> items = new List<string>() { "foo", "boo", "john", "doe" };
Console.WriteLine(string.Join(",", items));
编码快乐!
注意:这个答案不使用LINQ来生成连接的字符串。使用LINQ将枚举对象转换为带分隔符的字符串会导致严重的性能问题
现代。net(从。net 4开始)
这适用于数组、列表或任何实现IEnumerable类型:
string.Join(delimiter, enumerable);
这是一个可枚举的自定义对象:
string.Join(delimiter, enumerable.Select(i => i.Boo));
旧的。net(在。net 4之前)
这是一个字符串数组:
string.Join(delimiter, array);
这是针对List<string>:
string.Join(delimiter, list.ToArray());
这是一个自定义对象列表:
string.Join(delimiter, list.Select(i => i.Boo).ToArray());