是否有任何简单的LINQ表达式将我的整个List<string>集合项连接到具有分隔符字符的单个字符串?

如果集合是自定义对象而不是字符串呢?假设我需要连接object。name。


当前回答

好问题。我一直在用

List<string> myStrings = new List<string>{ "ours", "mine", "yours"};
string joinedString = string.Join(", ", myStrings.ToArray());

它不是LINQ,但它可以工作。

其他回答

注意:这个答案不使用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());

我认为如果你在扩展方法中定义逻辑,代码将更易于阅读:

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(", ");
List<string> strings = new List<string>() { "ABC", "DEF", "GHI" };
string s = strings.Aggregate((a, b) => a + ',' + b);

您可以使用聚合(Aggregate)将字符串连接成单个字符分隔的字符串,但如果集合为空,则会抛出无效操作异常(Invalid Operation Exception)。

可以将聚合函数与种子字符串一起使用。

var seed = string.Empty;
var seperator = ",";

var cars = new List<string>() { "Ford", "McLaren Senna", "Aston Martin Vanquish"};

var carAggregate = cars.Aggregate(seed,
                (partialPhrase, word) => $"{partialPhrase}{seperator}{word}").TrimStart(',');

你可以用字符串。Join并不关心您是否传递给它一个空集合。

var seperator = ",";

var cars = new List<string>() { "Ford", "McLaren Senna", "Aston Martin Vanquish"};

var carJoin = string.Join(seperator, cars);

我已经使用LINQ做到了这一点:

var oCSP = (from P in db.Products select new { P.ProductName });

string joinedString = string.Join(",", oCSP.Select(p => p.ProductName));