gpt4 book ai didi

Python/MySQL : Select data in a for loop

转载 作者:行者123 更新时间:2023-11-29 22:35:56 27 4
gpt4 key购买 nike

如果我似乎无法用语言表达我的问题,我深表歉意。基本上,我正在编写一个消息传递系统,用户可以在其中向其他用户发送消息并在收件箱中查看他们的消息。以下是我的数据库和 GUI 的一些屏幕截图: http://imgur.com/a/ra5Di

这是我在收件箱中显示消息的函数:

#DISPLAY MESSAGE IN INBOX FUNCTION
def displayMessageInbox(mf, c, vm):
recipient = config.nameInput

cursor.execute("""SELECT CONCAT('Title: ', m.title, '\n',
'From: ', s.sender, '\n',
'Sent: ', s.timeSent)
FROM Message m
INNER JOIN SentMessage s ON m.id = s.messageID
WHERE s.recipient = %s""", (recipient))
rows = cursor.fetchall()

i = 3
for message in rows:
messageInfo = tk.Label(mf, text=message, bg="white", anchor=tk.W,
justify=tk.LEFT, width=30)
messageInfo.grid(row=i, column=0, sticky=tk.W)
viewReply = tk.Button(mf, text="View/Reply", anchor=tk.W,
command=lambda:c.show_frame(vm))
viewReply.grid(row=i, column=1,padx=10, sticky=tk.W)
i+=1

这是我在用户单击“查看/回复”后显示消息及其内容的函数。请注意,它选择的是特定的消息 ID,而不是我实际希望它显示的消息 ID。换句话说,它只是占位符。

#READ MESSAGE CONTENT FUNCTION
def readMessage(mf):
mID = 'a6bb9c97-0f59-44ea-9f2b-759ffbac5031'

cursor.execute("""SELECT CONCAT('From: ', sm.sender, '\n',
'Title: ', m.title, '\n',
'Message: ', m.content)
FROM Message m
INNER JOIN SentMessage sm ON m.id = sm.messageID
WHERE m.id = %s""", (mID))
rows = cursor.fetchone()

message = rows[0]
readMessageLabel = tk.Label(mf, text=message, bg="white", anchor=tk.W,
justify=tk.LEFT, width=100)
readMessageLabel.grid(row=3, column=0, padx=10, sticky=tk.W)

所以我的问题是这样...我希望用户能够单击“查看/回复”并查看相应的消息,而不仅仅是占位符。我什至不知道如何开始解决这个问题。我认为我想要做的是从 displayMessageInfo 的 for 循环中的特定行获取消息 id,但我不完全确定。有什么想法吗?

最佳答案

显然,mID是一个静态值。您需要通过在用户按下“查看/回复”后将其值传递到 readMessage 函数(以相应消息为条件)来使该变量动态化。

虽然我不知道应用程序界面控件的设置,但请考虑:1) 查询消息 ID,2) 将其保存到变量,3) 将其传递到函数中。也许这可以帮助您开始:

def displayMessageInbox(mf, c, vm):
recipient = config.nameInput

cursor.execute("""SELECT m.id, CONCAT('Title: ', m.title, '\n',
'From: ', s.sender, '\n',
'Sent: ', s.timeSent) As messagetxt
FROM Message m
INNER JOIN SentMessage s ON m.id = s.messageID
WHERE s.recipient = %s""", (recipient))

i = 3
for message in cursor.fetchall():
mID = message[0]
messagetxt = message[1]
...

if (viewReply == somevalue): # ENTER LOGIC TO CAPTURE WHICH MESSAGE USER SELECTED
readMessage(mf, mID)

def readMessage(mf, mID):

cursor.execute("""SELECT CONCAT('From: ', sm.sender, '\n',
'Title: ', m.title, '\n',
'Message: ', m.content)
FROM Message m
INNER JOIN SentMessage sm ON m.id = sm.messageID
WHERE m.id = %s""", (mID))
rows = cursor.fetchone()

message = rows[0]
...

关于Python/MySQL : Select data in a for loop,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/29551427/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com