【问题标题】:Ignoring one specific or any special character while searching in pymongo在 pymongo 中搜索时忽略一个特定或任何特殊字符
【发布时间】:2019-05-18 05:50:58
【问题描述】:

所以我的 mongodb 中有一些产品如下所列

  1. 圣诞老人糖果
  2. 赫利甜
  3. 质量上乘

现在我得到的搜索是小写的,有时可能带有特殊字符或没有特殊字符。那么如何构建一个可以准确给出输出的查询呢?例如,如果用户输入了“quality sweet”,那么它应该匹配我的 mongodb 中的“Quality-Sweet”。如果用户以大写形式输入了“HERLEYS SWEET”,那么它应该匹配“herleys sweet”(如上图在我的 MongoDB 中所示)

db.product.find({"Product":re.compile('^' + re.escape(pr) + '$',re.IGNORECASE)})

我有上面的查询,它适用于大写或小写,但如果用户正在搜索“herleys-sweet”之类的东西,那么它就不起作用了。

【问题讨论】:

    标签: python regex mongodb pymongo


    【解决方案1】:

    您可以做的一件事是使用re.sub() 函数将特殊字符替换为其他字符。

    你可以有这样的东西:

    db.product.find({"Product":re.compile('^' + re.sub('[<list of special characters>]', '<string to replace with>', pr) + '$',re.IGNORECASE)})
    

    例如:

    • 创建特殊字符列表:[\-\_\~\!\\\/\^\$\%]

    • 选择用什么替换特殊字符。可以是空格' ' 或任何.*

    那么,你会:

    db.product.find({"Product":re.compile('^' + re.sub('[\-\_\~\!\\\/\^\$\%]', '.*', pr) + '$',re.IGNORECASE)})
    

    【讨论】:

    • 感谢您提供宝贵的解决方案。这解决了我的问题。 Qudos 给你。
    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2023-02-15
    • 1970-01-01
    • 1970-01-01
    • 2010-11-20
    • 2016-10-08
    • 2013-12-11
    相关资源
    最近更新 更多