[C#] C #의 목록에서 항목을 제거하는 방법은 무엇입니까?

다음과 같이 결과 목록에 저장된 목록이 있습니다.

var resultlist = results.ToList();

다음과 같이 보입니다 :

ID FirstName  LastName
-- ---------  --------
1  Bill       Smith
2  John       Wilson
3  Doug       Berg

목록에서 ID 2를 어떻게 제거합니까?



답변

List<T> 사용할 수있는 두 가지 방법이 있습니다.

항목의 색인을 알고 있으면 RemoveAt (int index)를 사용할 수 있습니다. 예를 들면 다음과 같습니다.

resultlist.RemoveAt(1);

또는 Remove (T item)을 사용할 수 있습니다 .

var itemToRemove = resultlist.Single(r => r.Id == 2);
resultList.Remove(itemToRemove);

항목이 실제로 존재하는지 확실하지 않은 경우 SingleOrDefault 를 사용할 수 있습니다 . 항목이 없으면 SingleOrDefault반환 null합니다 ( Single항목을 찾을 수 없으면 예외가 발생 함). 중복 값이있는 경우 두 가지가 모두 발생합니다 (같은 두 항목 id).

var itemToRemove = resultlist.SingleOrDefault(r => r.Id == 2);
if (itemToRemove != null)
    resultList.Remove(itemToRemove);


답변

짧은 답변 :
제거 (목록에서 results)

results.RemoveAll(r => r.ID == 2);ID가 2 인 항목이 results제자리 에 제거됩니다 .

필터 (원본 목록에서 제거하지 않고 results) :

var filtered = result.Where(f => f.ID != 2);ID가 2 인 항목을 제외한 모든 항목을 반환합니다.

자세한 답변 :

나는 생각한다 .RemoveAll()제거하려는 항목 ID 목록을 가질 수 있기 때문에 매우 유연 합니다. 다음 예를 고려하십시오.

당신이 가지고 있다면:

class myClass {
    public int ID; public string FirstName; public string LastName;
}

results다음과 같이 값을 할당했습니다 .

var results=new List<myClass> {
    new myClass()  { ID=1, FirstName="Bill", LastName="Smith" },
    new myClass()  { ID=2, FirstName="John", LastName="Wilson" },
    new myClass()  { ID=3, FirstName="Doug", LastName="Berg" },
    new myClass()  { ID=4, FirstName="Bill", LastName="Wilson" },
};

그런 다음 제거 할 ID 목록을 정의 할 수 있습니다.

var removeList = new List<int>() { 2, 3 };

그리고 이것을 사용하여 제거하십시오.

results.RemoveAll(r => removeList.Any(a => a==r.ID));

항목 2와 3제거하고에 지정된대로 항목 1과 4를 유지합니다 removeList. 노트 이 자리에서 일어나는, 그래서 필요한 추가의 할당은이 없다는 것을.

물론 다음과 같은 단일 항목에 사용할 수도 있습니다.

results.RemoveAll(r => r.ID==4);

이 예에서는 ID가 4 인 Bill이 제거됩니다.


DotNetFiddle : 데모 실행


답변

resultList = results.Where(x=>x.Id != 2).ToList();

내가 좋아하는 작은 Linq 도우미가 있습니다. 구현하기 쉽고 “아닌 곳”조건의 쿼리를 좀 더 읽기 쉽게 만들 수 있습니다.

public static IEnumerable<T> ExceptWhere<T>(this IEnumerable<T> source, Predicate<T> predicate)
{
    return source.Where(x=>!predicate(x));
}

//usage in above situation
resultList = results.ExceptWhere(x=>x.Id == 2).ToList();


답변

다른 접근법이 있습니다. 그것은 사용 List.FindIndex하고 List.RemoveAt.

나는 것이지만 아마도 KeithS 제시 솔루션 (단지 간단한 사용 Where/ ToList그것이에서)이 접근 다릅니다 변이 원래 목록 개체를. 이것은 기대에 따라 좋은 (또는 나쁜) “기능”이 될 수 있습니다.

어쨌든 FindIndex(가드와 결합 된)는 RemoveAtID에 간격이 있거나 순서가 잘못 된 경우 올바른지 확인하고 RemoveAt(vs Remove) 를 사용하면 목록을 통한 두 번째 O (n) 검색을 피할 수 있습니다.

LINQPad 스 니펫 은 다음과 같습니다 .

var list = new List<int> { 1, 3, 2 };
var index = list.FindIndex(i => i == 2); // like Where/Single
if (index >= 0) {   // ensure item found
    list.RemoveAt(index);
}
list.Dump();        // results -> 1, 3

행복한 코딩.


답변

어떤 종류의 목록을 지정하지 않지만 일반 목록은 RemoveAt(index)메소드 또는 메소드를 사용할 수 있습니다 Remove(obj).

// Remove(obj)
var item = resultList.Single(x => x.Id == 2);
resultList.Remove(item);

// RemoveAt(index)
resultList.RemoveAt(1);


답변

더 단순화 :

resultList.Remove(resultList.Single(x => x.Id == 2));

새로운 var 객체를 만들 필요가 없습니다.


답변

… 또는 resultlist.RemoveAt(1)정확히 색인을 알고 있다면.