sql >> Databáze >  >> NoSQL >> MongoDB

Pymongo Regex $všechny více hledaných výrazů

Ve smyčce for vytváříte řetězec, nikoli seznam re.compile objektů. Chcete:

collected_x = []                            # Initialize an empty list

for x in input:                             # Iterate over input
  collected_x.append(re.compile(x))         # Append re.compile object to list

collected_x_cut = collected_x[:-2]          # Slice the list outside the loop

cursor = db.collection.find({"key": {"$all": collected_x_cut}})

Jednoduchým přístupem by bylo použít map k vytvoření seznamu:

collected = map(re.compile, input)[:-2]
db.collection.find({"key": {"$all": collected}})

Nebo list comprehension :

collected = [re.compile(x) for x in input][:-2]
db.collection.find({"key": {"$all": collected}})



  1. Vytvořte zástupný textový index v MongoDB

  2. Postgres 9.4 jsonb se dotazuje na základní operátory

  3. arrayFilters při aktualizaci mongodb php

  4. Vrácení pole vnořených dokumentů prostřednictvím Meteor / Mongo