是否有一种简单的LINQ表达式,可以使用分隔符将我整个List<string>
集合中的所有项连接成一个string
?
如果集合是自定义对象而不是string
呢?想象一下我需要在object.Name
上进行连接。
是否有一种简单的LINQ表达式,可以使用分隔符将我整个List<string>
集合中的所有项连接成一个string
?
如果集合是自定义对象而不是string
呢?想象一下我需要在object.Name
上进行连接。
string result = String.Join(delimiter, list);
足够。
<String>
以外的其他事物,并将调用 ToString() 方法。 - KianList<string>
永远不会是一个查询到数据库的操作。这是完全不同的问题,但你总是可以调用 .ToList()
将查询结果合并后再进行操作。 - Sedat Kapanoglu虽然这个答案可以得到所需的结果,但与其他答案相比,它的性能较差。在决定是否使用它时要非常小心。
使用LINQ,应该会起作用;
string delimiter = ",";
List<string> items = new List<string>() { "foo", "boo", "john", "doe" };
Console.WriteLine(items.Aggregate((i, j) => i + delimiter + j));
类描述:
public class Foo
{
public string Boo { get; set; }
}
使用方法:
class Program
{
static void Main(string[] args)
{
string delimiter = ",";
List<Foo> items = new List<Foo>() { new Foo { Boo = "ABC" }, new Foo { Boo = "DEF" },
new Foo { Boo = "GHI" }, new Foo { Boo = "JKL" } };
Console.WriteLine(items.Aggregate((i, j) => new Foo{Boo = (i.Boo + delimiter + j.Boo)}).Boo);
Console.ReadKey();
}
}
这是我的最佳作品 :)
items.Select(i => i.Boo).Aggregate((i, j) => i + delimiter + j)
注意:此答案不使用LINQ来生成连接字符串。使用LINQ将可枚举对象转换为分隔字符串可能会导致严重的性能问题。
这适用于数组、列表或任何实现IEnumerable接口的类型:
string.Join(delimiter, enumerable);
这是针对自定义对象的可枚举性:
string.Join(delimiter, enumerable.Select(i => i.Boo));
以下代码适用于字符串数组:
string.Join(delimiter, array);
这是一个 List<string>:
string.Join(delimiter, list.ToArray());
而这是针对自定义对象列表的:
string.Join(delimiter, list.Select(i => i.Boo).ToArray());
using System.Linq;
public class Person
{
string FirstName { get; set; }
string LastName { get; set; }
}
List<Person> persons = new List<Person>();
string listOfPersons = string.Join(",", persons.Select(p => p.FirstName));
好问题。我一直在使用
List<string> myStrings = new List<string>{ "ours", "mine", "yours"};
string joinedString = string.Join(", ", myStrings.ToArray());
这不是 LINQ,但它可以工作。
你可以简单地使用:
List<string> items = new List<string>() { "foo", "boo", "john", "doe" };
Console.WriteLine(string.Join(",", items));
愉快地编码吧!
我认为如果你将逻辑定义在扩展方法中,代码会更易读:
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);
我已经使用LINQ完成了这个操作:
var oCSP = (from P in db.Products select new { P.ProductName });
string joinedString = string.Join(",", oCSP.Select(p => p.ProductName));
string.Join
建议即可。
这个回答是由问题的第二部分(通用方法)以及一些表达对LINQ的深刻喜爱的评论所促成的。
ToString
不能产生期望的结果时。(这可以通过添加对Select
的调用来解决。)static string Serialize<T>(IEnumerable<T> enumerable, char delim, Func<T, string> toString)
{
return enumerable.Aggregate(
new StringBuilder(),
(sb, t) => sb.Append(toString(t)).Append(delim),
sb =>
{
if (sb.Length > 0)
{
sb.Length--;
}
return sb.ToString();
});
}
string.Join
as suggested,在需要先处理序列时添加Select
。