1

我正在尝试获取字符串列表并基于列表中所有字符串的组合或组合进行查询。我想知道这样的事情是否可以在下面完成。

def filters(self,filter_company = ["DPL"]):
print "TEST"
        # Company Filter
        company_conj = 1        ## Bitwise 1 with AND will not effect other AND bits
        for c in filter_company:
            company_conj = (company_conj) & (Exception.company == c)            ## Create co


    qrty_exceptions = session.query(Exception).filter(company_conj)         ## Query by conjunction

所以基本上,我正在遍历列表中的每个项目并尝试通过连接来进行连接。关键是我不知道列表中有多少项目......但我想在逻辑上将它们按位与在一起,以便它们都形成合取。我最终收到以下错误:

TypeError: &: 'int' 和 BinaryExpression 的不支持的操作数类型

实际上,我的意思不是用按位或符号来写这个……“|” 但我想如果你可以为 AND 做到这一点,那么它也应该适用于 OR。

4

1 回答 1

1

我认为下面的示例应该对您有所帮助:

from sqlalchemy import or_, and_

company_filters = ["Filter1", "Filter2"]  # as many as you like

clauses = [(Exception.company == c) for c in company_filters]
q = session.query(Exception)
q = q.filter(and_(*clauses))  # or `or_(*clauses)`
于 2015-08-16T09:46:31.753 回答