Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

LinQ WHERE string.Contains or string.IndexOf?

Tags:

c#

.net

linq

I need to write something that would give the same result as:

var result = collection.Where( o => o.Name.IndexOf( "some_string2" ) != -1 || o.Name.IndexOf( "some_string_2" ) != -1 || o.Name.IndexOf( "some_string3" ) != -1 )

Where the amount and values of the strings to check for (some_string_1, 2 and 3) are unknown (coming from DB), so something more generic...

I tried the following, but failed...

var stringsToCheck = someCommaSeparatedStrings.ToLower().Split( ',' ).ToList();
var result = collection.Where( o => stringsToCheck.Contains( o.ToLower() ) );

In other words, I need to retrieve all the objects from a collection which names contain some specific strings.

like image 821
Seb Avatar asked Jan 15 '13 21:01

Seb


2 Answers

var result = collection.Where(item => stringsToCheck.Any(stringToCheck => 
    item.Name.Contains(stringToCheck)));

Read in English this is: give me all of the items in the collection where, of all of the strings to check one of them is a substring of the string in the collection.

like image 139
Servy Avatar answered Oct 04 '22 23:10

Servy


If you want to test whether o.Name contains a stringToCheck then:

var result = collection.Where( o => stringsToCheck.Any(a => o.Name.Contains(a)));

If you only need to test for equality, then:

var result = collection.Where( o => stringsToCheck.Contains(o.Name));

Note: if you need to apply case normalisation then ToLower() should be applied accordingly.

like image 39
Chamila Chulatunga Avatar answered Oct 04 '22 21:10

Chamila Chulatunga