bind。()函数仅发送最后一个参数

时间:2019-03-28 13:39:43

标签: python tkinter sqlite

我正在使用tkinter在python中使用聊天程序,我想使用户能够单击名称并在新的tkinter窗口中打开聊天,但是当我单击名称时,只会传递姓氏

我最初使用while循环来遍历数据库中的不同用户。

希望可以修复该错误,所以我切换到了for循环,但未进行任何更改。

这是我当前的代码:

def openchat(event):
root= Tk()
root.title(contactname)
print("everything binds to this")
print("contactname: %s" % contactname)


def contacts():

c.execute("SELECT contact_id FROM contacts WHERE user_id = ?", (session_id[0], ))
row = c.fetchall();

print("prints contact id: %s" % row, "\n")
rowlength = len(row)
x = 0
print(row[x][0])

#while x < rowlength:
for i in row:
    c.execute("SELECT * FROM users WHERE user_id = ?", (row[x][0], ))
    row2 = c.fetchone();
    print("('contact_id', 'contactname', 'password', 'chat_id')")
    print(row2)
    contactname[0] = row2[1]
    print("contactname: %s" % contactname, "x: %s" % x, "\n")
    contactframe = Frame(leftframe, bg="#00A098", highlightthickness=2.5, highlightbackground="Black")
    contactframe.pack(side = TOP, fill=X)
    contactframe.bind("<Button-1>", lambda event: openchat(contactname))
    n = Label(contactframe, text=contactname, fg="Black", bg='#00A098')
    n.config(font=("Ariel", 20))
    n.bind("<Button-1>", lambda event: openchat(contactname))
    n.pack()
    x+=1

这是我在运行程序时获得的终端输出:

contact function: 

prints contact id: [('2',), ('3',), ('4',)] 

2
('contact_id', 'contactname', 'password', 'chat_id')
('2', 'brian', 'brian', '2')
contactname: ['brian'] x: 0 

('contact_id', 'contactname', 'password', 'chat_id')
('3', 'abdi', 'abdi', '3')
contactname: ['abdi'] x: 1 

('contact_id', 'contactname', 'password', 'chat_id')
('4', 'john', 'john', '4')
contactname: ['john'] x: 2 

以上所有功能都能按预期完美运行,但这就是我搞砸的地方。一切都绑定到最后一个联系人,约翰

contactname: ['john']
contactname: ['john']
contactname: ['john']

但是它应该显示如下内容:

contactname: ['brian']
contactname: ['abdi']
contactname: ['john']

我目前的理论是,绑定功能仅在单击按钮时运行,因此仅输出最后一个联系人姓名,但是我可能是错的。

如果有人可以告诉我我做错了什么或向正确的方向指出,我们将不胜感激。

预先感谢

=============

我想出了一个对我有用的解决方案,如果有人遇到类似问题,这是我的最终代码:

def openchat(i):
  c.execute("SELECT * FROM users WHERE user_id = ?", (i, ))
  row = c.fetchall();
  contactname = row[0][1]
  root= Tk()
  root.title(contactname)
  print("contactname: %s" % contactname)


def contacts(self):

  c.execute("SELECT contact_id FROM contacts WHERE user_id = ?", (session_id[0], ))
  row = c.fetchall();

  print("prints contact id: %s" % row, "\n")
  rowlength = len(row)
  minrow = min(row)
  maxrow = max(row)
  minrow2 = minrow[0]
  maxrow2 = maxrow[0]
  minrow2 = int(minrow2)
  maxrow2 = int(maxrow2)
  x = 0
  print(row[x][0])

  for i in range(minrow2,maxrow2+1):

      self.contact_id = i
      c.execute("SELECT * FROM users WHERE user_id = ?", (row[x][0], ))
      row2 = c.fetchone();
      print(row2)
      contactname[0] = row2[1]
      print("contactname: %s" % contactname, "x: %s" % x, "\n")
      contactframe = Frame(leftframe, bg="#00A098", highlightthickness=2.5, highlightbackground="Black")
      contactframe.pack(side = TOP, fill=X)
      n = Button(contactframe, text=contactname, fg="Black", bg='#00A098', command = lambda i=i: openchat(i))
      #n.config(font=("Ariel", 20))
      n.pack()
      x+=1

1 个答案:

答案 0 :(得分:0)

  

评论:当我使用'text'时遇到此错误_tkinter.TclError: unknown option "-text"

以下对我有用:

class App(tk.Tk):
    def __init__(self):
        super().__init__()

        n = tk.Label(self, text='test', fg="Black", bg='#00A098')
        n.config(font=("Ariel", 20))
        n.bind("<Button-1>", self.openchat)
        n.grid(row=0, column=0)

    def openchat(self, event):
        print("event from {}".format(type(event.widget))
        # >>> event from <class 'tkinter.Label'>
        print("event from {}".format(event.widget['text']))
        # >>> event from test

if __name__ == "__main__":
    App().mainloop()

使用Python测试:3.5-'TclVersion':8.6'TkVersion':8.6