是否有任何简单的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());