在标签 tkinter 上打印

Print on Label tkinter

与 PostgreSQL 数据库建立连接,我想在标签中显示一个手工制作的 table,在我的数据库上制作一个 SELECT。数据库连接和查询就可以了。但是出了点问题。我将程序显示的源代码和屏幕截图放在下方。

from tkinter import *
import psycopg2 # LIBRARY FOR CONNECT TO THE POSTGRESQL DB

root = Tk()
menubar = Menu(root)

file = Menu(menubar, tearoff=0)
file.add_command(label="Exit", command=root.quit)
menubar.add_cascade(label="Principal", menu=file)

con = psycopg2.connect(  # CONNECT TO THE POSTGRESQL DB
    host="localhost",
    database="escola",
    user="postgres",
    password=248657
)

v = StringVar()

cur = con.cursor()  # CURSOR
cur.execute("SELECT id, nome, dt_nasc, nome_mae, nome_pai FROM alunos")  # EXECUTE QUERY

rows = cur.fetchall()

v.set('+----+-----------------------------+--------------------+-----------------------------+-----------------------------+')
v.set('|ID'.ljust(5) + '| Nome'.ljust(30) + '| Data de Nascimento |'.ljust(21) + ' Nome da     Mãe'.ljust(29) + '| Nome do Pai'.ljust(30) + '|')
v.set('+----+-----------------------------+--------------------+-----------------------------+------    -----------------------+')
for r in rows:
    v.set(f'|{r[0]}'.ljust(5) + f'|  {r[1]}'.ljust(30) + f'|  {r[2]}'.ljust(21) + f'|      {r[3]}'.ljust(30) + f'|  {r[4]}'.ljust(30) + '|')
v.set('+----+-----------------------------+--------------------+-----------------------------+------    -----------------------+')

cur.close()  # CLOSE CURSOR


box = Label(root, textvariable=v).pack() # THE LABEL

root.config(menu=menubar) # SETTING THE MENU
root.mainloop()

屏幕截图:

这里发生的事情是你用每一行覆盖了 v。相反,请考虑编写一个多行字符串,然后将该最终值设置为 v.

也就是说,您可能还想尝试一些其他选项。例如,您可以使用一个文本框,然后在新行的末尾使用 insert() 就可以了。或者更好的是,在处理数据集时,您可能希望使用 Treeview 来组织数据。

试试这个,如果您有任何问题,请告诉我:

替换为:

v.set('+----+-----------------------------+--------------------+-----------------------------+-----------------------------+')
v.set('|ID'.ljust(5) + '| Nome'.ljust(30) + '| Data de Nascimento |'.ljust(21) + ' Nome da     Mãe'.ljust(29) + '| Nome do Pai'.ljust(30) + '|')
v.set('+----+-----------------------------+--------------------+-----------------------------+------    -----------------------+')
for r in rows:
    v.set(f'|{r[0]}'.ljust(5) + f'|  {r[1]}'.ljust(30) + f'|  {r[2]}'.ljust(21) + f'|      {r[3]}'.ljust(30) + f'|  {r[4]}'.ljust(30) + '|')
v.set('+----+-----------------------------+--------------------+-----------------------------+------    -----------------------+')

有了这个:

separator = '+----+-----------------------------+--------------------+-----------------------------+-----------------------------+'
prep_string = ''''''

prep_string = '{}{}\n'.format(prep_string, separator)
prep_string = '{}{}\n'.format('|ID'.ljust(5) + '| Nome'.ljust(30) + '| Data de Nascimento |'.ljust(21) + ' Nome da     Mãe'.ljust(29) + '| Nome do Pai'.ljust(30) + '|')
prep_string = '{}{}\n'.format(prep_string, separator)
for r in rows:
    prep_string = '{}{}\n'.format(f'|{r[0]}'.ljust(5) + f'|  {r[1]}'.ljust(30) + f'|  {r[2]}'.ljust(21) + f'|      {r[3]}'.ljust(30) + f'|  {r[4]}'.ljust(30) + '|')
prep_string = '{}{}\n'.format(prep_string, separator)

v.set(prep_string)

如果我们打印 prep_string 的值,我们会立即包含您尝试添加的所有内容。请注意下面我只是将您的变量引用到一个字符串中以显示它是如何工作的。您的值应该代表您拥有的任何数据。

+----+-----------------------------+--------------------+-----------------------------+-----------------------------+
|ID'.ljust(5) + '| Nome'.ljust(30) + '| Data de Nascimento |'.ljust(21) + ' Nome da     Mãe'.ljust(29) + '| Nome do Pai'.ljust(30) + '|
+----+-----------------------------+--------------------+-----------------------------+-----------------------------+
|ID'.ljust(5) + '| Nome'.ljust(30) + '| Data de Nascimento |'.ljust(21) + ' Nome da     Mãe'.ljust(29) + '| Nome do Pai'.ljust(30) + '|
|ID'.ljust(5) + '| Nome'.ljust(30) + '| Data de Nascimento |'.ljust(21) + ' Nome da     Mãe'.ljust(29) + '| Nome do Pai'.ljust(30) + '|
|ID'.ljust(5) + '| Nome'.ljust(30) + '| Data de Nascimento |'.ljust(21) + ' Nome da     Mãe'.ljust(29) + '| Nome do Pai'.ljust(30) + '|
+----+-----------------------------+--------------------+-----------------------------+-----------------------------+

对于文本小部件版本,请尝试这样的操作:

import tkinter as tk

separator = '+----+-----------------------------+--------------------+-----------------------------+-----------------------------+'

root = tk.Tk()
text = tk.Text(root, wrap='none', font='TkFixedFont', width=130)
text.pack()

text.insert('end', separator + '\n')
text.insert('end', '''|ID'.ljust(5) + '| Nome'.ljust(30) + '| Data de Nascimento |'.ljust(21) + ' Nome da     Mãe'.ljust(29) + '| Nome do Pai'.ljust(30) + '|''' + '\n')
text.insert('end', separator + '\n')
for r in range(3):
    text.insert('end', '''|ID'.ljust(5) + '| Nome'.ljust(30) + '| Data de Nascimento |'.ljust(21) + ' Nome da     Mãe'.ljust(29) + '| Nome do Pai'.ljust(30) + '|''' + '\n')
text.insert('end', separator + '\n')

root.mainloop()

结果: