相关疑难解决方法(0)

flake8抱怨过滤子句中的布尔比较"=="

我在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".有人可以告诉我如何处理这种情况.我不想禁用片状.

python mysql sqlalchemy flake8

46
推荐指数
3
解决办法
1万
查看次数

优雅的方式来过滤无或非无

以下 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)

添加过滤器的更优雅的方式是什么?

python sqlalchemy

4
推荐指数
1
解决办法
2120
查看次数

标签 统计

python ×2

sqlalchemy ×2

flake8 ×1

mysql ×1