1

我在python中有以下代码。我收到此错误->元组索引必须是整数,而不是 str

如何将这些值传递到查询中?我有其他例子,这种方法完美地工作,我不明白为什么它在这里失败。

def request_events_json(uei,interval,conn):

    cur = conn.cursor()

    events_query ="""select e.nodeid,n.nodelabel,e.ipaddr,count(*) as total,min(e.eventcreatetime),max(e.eventcreatetime),(regexp_matches (e.eventlogmsg,E': %(.*)'))[1] as msglog
                     from events e, node n where e.eventuei = (%s)  and e.eventcreatetime > now() - interval (%s) and n.nodeid=e.nodeid
                     group by n.nodelabel,e.nodeid,e.ipaddr,msglog
                     order by e.nodeid, count(*) desc limit 10;"""



    try:
       print('## Requesting events ##')
       cur.execute(events_query,('uei.opennms.org/syslogd/cisco/line','5 min'))
       .......
4

1 回答 1

1

在我的 PostgreSQL 版本中,后面的圆括号interval是被禁止的。

更新:

它是正则表达式中的百分号。加倍。

于 2012-07-04T11:33:25.920 回答