LINQ를 사용하여 List <string> 내의 모든 문자열 연결


542

전체 List<string>컬렉션 항목을 string구분 기호 문자 가있는 단일 항목에 연결하기 쉬운 LINQ 표현식이 있습니까?

컬렉션이 아닌 사용자 지정 개체로 구성된 컬렉션은 무엇입니까 string? 에 연결해야한다고 상상해보십시오 object.Name.


37
왜 linq가 아닌 string.Join ()?
Alan

14
string.Join이 더 좋지만 linq가 코드를 재미있게 만든다고 생각합니다.
Ali Ersöz

14
String.Join은 StringBuilder를 사용하고 반복 연결의 내재 된 O (n ^ 2) 성능을 피하기 때문에 더 좋습니다.
Kennet Belenky 2016 년

1
LINQ를 사용하는 성능 문제
PreguntonCojoneroCabrón

답변:


524

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)

40
O (n ^ 2) 시간이 다시칩니다.
Kennet Belenky 2016 년

2
집계 방법을 볼 수 없으면 System.Linq를 사용하여 추가해야합니다.
Cédric Guillemette

6
문제는 위의 LinQ 메소드가 비어 있거나 단일 요소 목록에서 작동하지 않는다는 것입니다.
Alexander

2
항목이 비어있는 경우 InvalidOperationException이 발생합니다.
2xMax

10
왜 string.join을 사용하지 않습니까? Sedat가 더 나은 선택 일 때 급한 사람이이 솔루션을 선택하지 않도록 Sedat의 답변을 수락하십시오.
Skychan

966

.NET 4.0 이상 버전 :

String.Join(delimiter, list);

충분하다.


91
나는 LINQ 솔루션에 모두 적합하지만 LINQ 및 Aggregate () 메서드보다 효율적입니다.
andleer

17
훨씬 더 깨끗합니다! 나를 위해 일했다! string.Join ( ",", accs.Select (x => x.AccountID) .ToArray ()),
m4tt1mus

32
OP가 LINQ에 있어야한다는 것을 분명히하기 전에 @KonstantinSalavatov 나는 내 대답을 게시했습니다. Google에서 "필요하지 않은 LINQ"솔루션을 찾는 동안이 답변에 부딪친 사람에게는 여전히 타당합니다. 이 맥락에서 "유용하지 않다"라는 대답은 불공평합니다.
Sedat Kapanoglu 2016 년

7
이것은 List 이외의 것들에도 사용될 수 <String>있으며 ToString () 메소드를 호출합니다.
키안

데이터베이스로 이동하는 쿼리 인 경우 작동하지 않습니다. 메모리에서만 작동합니다.
alansiqueira27

124

이것은 문자열 배열입니다.

string.Join(delimiter, array);

이것은 List <string>입니다.

string.Join(delimiter, list.ToArray());

그리고 이것은 커스텀 객체의 목록입니다.

string.Join(delimiter, list.Select(i => i.Boo).ToArray());

25
당신이 ToArray () 호출 필요가 없습니다 String.Join이를 IEnumerable 소요 과부하가 있습니다
arolson101

9
IEnumerable 과부하는 4.0 이상에서만 존재합니다. 이전 버전을 사용하는 경우 여전히 ToArray ()가 필요합니다.
Rakuen42

2
아! 그 마지막 과부하는 내가 찾던 것이 었습니다. 특정 속성을 추출 할 방법이 있어야한다는 것을 알고있었습니다. :)
Mike Devenney

56
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));

26

좋은 질문. 나는 사용하고있다

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

LINQ는 아니지만 작동합니다.


왜 .ToArray ()를 호출해야합니까?
Ε Г И І И О

2009 년의 나쁜 OLE 시절로 돌아가서 string.Join에는 IEnumerable을 허용하는 확장명이 없었습니다.
Jacob Proffitt

8
List<string> strings = new List<string>() { "ABC", "DEF", "GHI" };
string s = strings.Aggregate((a, b) => a + ',' + b);

7

확장 방법으로 논리를 정의하면 코드를 훨씬 더 읽기 쉽다고 생각합니다.

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(", ");

6

간단하게 사용할 수 있습니다 :

List<string> items = new List<string>() { "foo", "boo", "john", "doe" };

Console.WriteLine(string.Join(",", items));

행복한 코딩!


3

LINQ를 사용 하여이 작업을 수행했습니다.

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

string joinedString = string.Join(",", oCSP.Select(p => p.ProductName));
당사 사이트를 사용함과 동시에 당사의 쿠키 정책개인정보 보호정책을 읽고 이해하였음을 인정하는 것으로 간주합니다.
Licensed under cc by-sa 3.0 with attribution required.