pyDatalog:在询问查询时,'对象与查询的类不兼容'

时间:2013-08-27 13:56:58

标签: python logic-programming datalog

我正在开发一个使用pyDatalog查询sqlite数据库的程序。数据库中的密钥表是Event,其定义如下:

class Event(Base):
  __tablename__ = 'Event'

  id = Column('id', Integer, primary_key = True)
  eventType = Column('eventType', Integer, ForeignKey('EventType.id'))
  dateTime = Column('dateTime', DateTime)

  def __init__(self, eventType, dateTime):
    self.eventType = eventType
    self.dateTime = dateTime

  def __repr__(self):
    return "<Event(%d, %d, %s)>" % (self.id, self.eventType, self.dateTime)

然后,每个事件都会引用一个包含更多信息的详细信息表。

我希望能够对序列中的每个事件运行一系列查询。使用pyDatalog.load()

从外部文件加载规则集

我遇到问题的部分是将每个事件id的引用从python传递到datalog中。我一直收到错误“TypeError:Object与查询的类不兼容。”

我已将规则缩减到这些以进行调试:

+ parent(bill, 'John Adams')
ancestor(X,Y) <= parent(X,Y)
ancestor(X,Y) <= parent(X,Z) & ancestor(Z,Y)

getEvent(EvtId, Evt) <= (Event.id[Evt] == EvtId)

询问查询的代码看起来像这样(较大类的一部分):

def validateEvent(self, event):
  # validate the event instance 'event'
  print "validating event: %s" % (event)
  #query = 'parent(bill, X)'
  query = 'getEvent(' + str(event.id) + ', Evt)'
  print query
  print pyDatalog.ask(query)

如果我取消注释“query ='parent(bill,X)'”行,它可以正常工作(它打印(bill,'John Adams')元组),但是使用“query ='getEvent(.. 。“行,它在上面显示的最后一行上一直没有出现上述错误。

有谁知道这个错误意味着什么,以及如何正确地将对事件id的引用传递给pyDatalog?

2 个答案:

答案 0 :(得分:0)

当pyDatalog解析前缀谓词时会生成此错误,例如(Event.id [Evt] == EvtId):这意味着Evt不是Event的实例,也不是pyDatalog变量。

因此,我可以想象你在这个内联pyDatalog语句中得到了错误。

getEvent(EvtId, Evt) <= (Event.id[Evt] == EvtId)

我无法解释你如何在这一行得到错误(使用pyDatalog 0.13):

print pyDatalog.ask(query)

答案 1 :(得分:0)

我通过重新阅读文档设法解决了这个问题。已经使用

将pyDatalog功能添加到基类
Base = declarative_base(cls=pyDatalog.Mixin, metaclass=pyDatalog.sqlMetaMixin)

您还需要将会话与基类相关联,并使用:

Session = sessionmaker(bind=engine)
session = Session()
Base.session = session

修复此问题后,上面的示例正常工作。