使用带有 OR 语句的 Find All 过滤列表

Filtering a list using Find All with an OR statement

if (product_search.Text.Trim() != "")
{
    filteredProductsList = filteredProductsList
      .FindAll(s => s.product.Contains(product_search.Text.Trim().ToUpper()));
}

如果产品包含搜索的文本,我有上面的代码可以过滤产品列表。但是,我希望此文本框根据 ProductBarcode 进行过滤。如果有办法 运行 FindAll() 但带有 OR 语句。那么过滤到产品是否包含搜索的文本或条形码?

像这样:

// Search if product_search is not all whitespace string
if (!string.IsNullOrWhiteSpace(product_search.Text)) {
  // let's extract a local  variable (readability) 
  string toFind = product_search.Text.Trim();

  // it seems you want case insensetive search: let's specify it clearly:
  // StringComparison.CurrentCultureIgnoreCase
  // trick: IndexOf(..., StringComparison.CurrentCultureIgnoreCase) >= 0 since
  //        we don't have appropriate Contains
  // Finally, you want || - either product or barCode should contain toFind
  filteredProductsList = filteredProductsList
    .FindAll(item => 
       item.product.IndexOf(toFind, StringComparison.CurrentCultureIgnoreCase) >= 0 ||
       item.barCode.IndexOf(toFind, StringComparison.CurrentCultureIgnoreCase) >= 0);
}

我不确定这个 filteredProductsList 是什么类型的列表,但我假设它是一个字符串列表,所以使用 linq 你可以做类似的事情

filteredProductsList = filteredProductsList.Where(x => x.product.Contains(toFind) || x.barcode.Contains(toFind)).ToList();

或者,如果您只想要相反的选择,您可以这样做

filteredProductsList = filteredProductsList.Where(x => !(x.product.Contains(toFind) || x.barcode.Contains(toFind))).ToList();