我在mysql db表中有一个布尔字段.
# table model
class TestCase(Base):
__tablename__ = 'test_cases'
...
obsoleted = Column('obsoleted', Boolean)
Run Code Online (Sandbox Code Playgroud)
要获得所有未经过时的测试用例的计数,可以像这样完成:
caseNum = session.query(TestCase).filter(TestCase.obsoleted == False).count()
print(caseNum)
Run Code Online (Sandbox Code Playgroud)
这很好,但是flake8报告了以下警告:
E712:与False的比较应该是"如果cond是假的:"或"如果不是cond:"
好的,我觉得这很有道理.所以将我的代码更改为:
caseNum = session.query(TestCase).filter(TestCase.obsoleted is False).count()
Run Code Online (Sandbox Code Playgroud)
要么
caseNum = session.query(TestCase).filter(not TestCase.obsoleted).count()
Run Code Online (Sandbox Code Playgroud)
但他们都不能奏效.结果始终为0.我认为filter子句不支持运算符"is"或"is not".有人可以告诉我如何处理这种情况.我不想禁用片状.
以下 SQLAlchemy 代码可以工作,但看起来不符合 Python 风格:
if has_died: # has_died: True or False
query = query.filter(User.died_at != None)
else:
query = query.filter(User.died_at == None)
Run Code Online (Sandbox Code Playgroud)
添加过滤器的更优雅的方式是什么?