def show_excel(self): # 清空第一个表格内容 self.result_text.delete(1.0, tk.END) # 清空第二个表格内容 if hasattr(self, 'table_frame2'): self.table_frame2.destroy() self.table_frame2 = tk.Frame(self.result_text2) self.table_frame2.pack(side=tk.LEFT, fill=tk.BOTH, expand=True) table_scroll_y2 = ttk.Scrollbar(self.table_frame2, orient=tk.VERTICAL) table_scroll_y2.pack(side=tk.RIGHT, fill=tk.Y) table_scroll_x2 = ttk.Scrollbar(self.table_frame2, orient=tk.HORIZONTAL) table_scroll_x2.pack(side=tk.BOTTOM, fill=tk.X) # 添加查询框和按钮 query_frame = tk.Frame(self.result_text2) query_frame.pack(side=tk.TOP, fill=tk.X) query_entry = tk.Entry(query_frame) query_entry.pack(side=tk.LEFT, padx=5, pady=5) query_button = tk.Button(query_frame, text='查询', command=lambda: self.query_data(query_entry.get(), table2)) query_button.pack(side=tk.LEFT, padx=5, pady=5) # 清空第二个表格内容 if hasattr(self, 'table_frame'): self.table_frame.destroy() self.table_frame = tk.Frame(self.result_text) self.table_frame.pack(side=tk.LEFT, fill=tk.BOTH, expand=True) table_scroll_y = ttk.Scrollbar(self.table_frame, orient=tk.VERTICAL) table_scroll_y.pack(side=tk.RIGHT, fill=tk.Y) table_scroll_x = ttk.Scrollbar(self.table_frame, orient=tk.HORIZONTAL) table_scroll_x.pack(side=tk.BOTTOM, fill=tk.X
时间: 2024-03-23 08:41:27 浏览: 80
根据您的最新回复,我猜测您的意思是:希望用户在查询框中按下回车键时,可以触发查询按钮的点击事件,从而实现查询操作。如果是这样的话,您可以通过下面的方式实现:
1.给查询框绑定回车键的事件处理函数:
```python
query_entry.bind("<Return>", self.query_by_enter)
```
2.在类中添加一个新的方法 self.query_by_enter,作为回车键的事件处理函数,该函数会调用查询按钮的回调函数:
```python
def query_by_enter(self, event):
self.query_data(query_entry.get(), table2)
```
3.将查询按钮的回调函数改为 self.query_by_enter:
```python
query_button = tk.Button(query_frame, text='查询', command=self.query_by_enter)
```
这样,当用户在查询框中按下回车键时,就会触发查询按钮的点击事件,从而实现查询操作。
相关问题
def show_excel(self): # 清空文本框 self.result_text.delete('1.0', tk.END) self.result_text2.delete('1.0', tk.END) # 获取出入库明细表格数据 for row in self.record_sheet.values: for cell in row: if cell is None: self.result_text.insert(tk.END, ' ' * 10) else: self.result_text.insert(tk.END, str(cell).ljust(10)) self.result_text.insert(tk.END, '\n') # 获取库存明细表格数据 for row in self.data_sheet.values: for cell in row: if cell is None: self.result_text2.insert(tk.END, ' ' * 10) else: self.result_text2.insert(tk.END, str(cell).ljust(10)) self.result_text2.insert(tk.END, '\n')修改這個代碼,顯示數據時需要用表格裱起來,並置中
你可以使用第三方库 `prettytable` 来实现表格的展示,并且使用 `tkinter` 的布局函数来实现置中。
首先,你需要在文件头部导入 `prettytable` 库:
```python
from prettytable import PrettyTable
```
然后,你需要修改 `show_excel` 方法,使用 `PrettyTable` 创建表格,将数据添加到表格中,最后在文本框中显示表格。同时,你需要使用 `tkinter` 的布局函数 `place` 来实现文本框的置中。
下面是修改后的代码:
```python
def show_excel(self):
# 清空文本框
self.result_text.delete('1.0', tk.END)
self.result_text2.delete('1.0', tk.END)
# 创建出入库明细表格
record_table = PrettyTable()
record_table.field_names = ['日期', '商品编号', '商品名称', '操作类型', '数量', '单价']
for row in self.record_sheet.values:
record_table.add_row(row)
# 创建库存明细表格
data_table = PrettyTable()
data_table.field_names = ['商品编号', '商品名称', '库存数量', '库存金额']
for row in self.data_sheet.values:
data_table.add_row(row)
# 在文本框中显示表格
record_text = tk.Text(self.root, height=20, width=80, font=('Arial', 10))
record_text.place(relx=0.5, rely=0.3, anchor='center')
record_text.insert(tk.END, record_table)
data_text = tk.Text(self.root, height=20, width=80, font=('Arial', 10))
data_text.place(relx=0.5, rely=0.7, anchor='center')
data_text.insert(tk.END, data_table)
```
其中,`relx=0.5, rely=0.3, anchor='center'` 表示将文本框的中心点置于窗口的中心点,`height=20, width=80` 表示文本框的高度和宽度。你可以根据实际情况进行调整。
def show_excel(self): # 清空文本框中的内容 self.result_text.delete("1.0", tk.END) self.result_text2.delete("1.0", tk.END) ws = self.record_sheet rows = ws.values # 将内容插入到文本框中 text_box = tk.Text(self.result_text) for row in rows: for cell in row: text_box.insert(tk.END, str(cell) + '\t') text_box.insert(tk.END, '\n') text_box.pack(side=tk.LEFT, fill=tk.BOTH, expand=True)修改顯示數據要跟表格一樣
要让显示的数据和表格对齐,您可以使用 `ljust()` 和 `rjust()` 方法来设置每个单元格的宽度,以确保所有单元格具有相同的宽度。例如,您可以将代码修改为:
```
text_box = tk.Text(self.result_text)
for row in rows:
for cell in row:
text_box.insert(tk.END, str(cell).ljust(20)) # 20是单元格的宽度
text_box.insert(tk.END, '\n')
text_box.pack(side=tk.LEFT, fill=tk.BOTH, expand=True)
```
这样,每个单元格都将具有相同的宽度,从而使显示的数据和表格对齐。您可以根据需要调整单元格的宽度。
阅读全文