仍然不起作用: self.columns = ("编号", "药品名", "产名", "库存", "价格","存放位置","生产日期","有效期") self.tree = ttk.Treeview(self.frame_tableshow, show="headings", height=25, columns=self.columns) self.vbar = ttk.Scrollbar(self.frame_tableshow, orient=VERTICAL, command=self.tree.yview) self.hbar = ttk.Scrollbar(self.frame_tableshow, orient=HORIZONTAL, command=self.tree.xview) # 定义树形结构与滚动条 self.tree.configure(yscrollcommand=self.vbar.set,xscrollcommand=self.hbar.set) # 表格的标题 self.tree.column("编号", width=100, anchor='center') # 表示列,不显示 self.tree.column("药品名", width=200, anchor='center') self.tree.column("产名", width=90, anchor='center') self.tree.column("库存", width=60, anchor='center') self.tree.column("价格", width=60, anchor='center') self.tree.column("存放位置",width=200,anchor='center') self.tree.column("生产日期",width=150,anchor='center') self.tree.column("有效期", width=150, anchor='center') # 调用方法获取表格内容插入 self.tree.grid(row=0, column=0, sticky=NSEW) self.vbar.grid(row=0, column=1, sticky=NS)#没看出来有什么用 self.hbar.grid(row=1,column=0, sticky=EW)
时间: 2024-03-11 22:50:34 浏览: 121
如果你已经将 `ttk.Scrollbar` 控件正确地放置在了 `ttk.Treeview` 控件的下方,但横向滚动条仍然无法正常工作,那么可能是因为你忘记了设置 `ttk.Treeview` 控件的 `xscrollcommand` 属性。
在你的代码中,你已经将 `ttk.Treeview` 控件的 `xscrollcommand` 属性设置为了 `self.hbar.set`,但如果你的滚动条仍然无法正常工作,可以尝试在 `ttk.Treeview` 控件的 `grid` 或 `pack` 方法中,使用 `xscrollcommand` 参数将滚动条与控件关联。
以下是一个示例代码:
```python
self.tree.grid(row=0, column=0, sticky=NSEW, xscrollcommand=self.hbar.set)
self.vbar.grid(row=0, column=1, sticky=NS)
self.hbar.grid(row=1, column=0, sticky=EW)
```
在这个示例中,我们使用 `xscrollcommand` 参数将 `self.hbar` 控件与 `self.tree` 控件关联。这将确保 `self.hbar` 控件能够正确地控制 `self.tree` 控件的横向滚动。
请注意,如果你的代码中使用了其他布局方法(如 `pack`),你需要根据自己的需要进行调整。
相关问题
self.columns = ("编号", "药品名", "产名", "库存", "价格","存放位置","生产日期","有效期") self.tree = ttk.Treeview(self.frame_tableshow, show="headings", height=25, columns=self.columns) self.vbar = ttk.Scrollbar(self.frame_tableshow, orient=VERTICAL, command=self.tree.yview) self.hbar = ttk.Scrollbar(self.frame_tableshow, orient=HORIZONTAL, command=self.tree.xview) # 定义树形结构与滚动条 self.tree.configure(yscrollcommand=self.vbar.set,xscrollcommand=self.hbar.set) # 表格的标题 self.tree.column("编号", width=100, anchor='center') # 表示列,不显示 self.tree.column("药品名", width=200, anchor='center') self.tree.column("产名", width=90, anchor='center') self.tree.column("库存", width=60, anchor='center') self.tree.column("价格", width=60, anchor='center') self.tree.column("存放位置",width=200,anchor='center') self.tree.column("生产日期",width=150,anchor='center') self.tree.column("有效期", width=150, anchor='center')横向滑动条不起作用,只能显示
在这段代码中,你已经正确地创建了一个横向滑动条 `self.hbar`,并将其与 `ttk.Treeview` 控件关联。但是,该滑动条并没有起作用的原因可能是因为你没有将滑动条放入相应的位置。你需要将滑动条放入 `ttk.Treeview` 控件的下方,并使用 `grid` 或 `pack` 方法进行布局。
以下是一个示例代码,你可以将其应用到你的程序中:
```python
self.vbar.grid(row=0, column=1, sticky="ns")
self.hbar.grid(row=1, column=0, sticky="ew")
self.tree.grid(row=0, column=0, sticky="nsew")
```
在这个示例中,我们使用 `grid` 方法将 `self.tree` 控件放置在第 0 行第 0 列,并将 `self.vbar` 控件放置在第 0 行第 1 列,将 `self.hbar` 控件放置在第 1 行第 0 列。我们还设置了 `sticky` 参数,以确保滑动条能够正确地占据相应的空间。
请注意,如果你的代码中还有其他布局方法(如 `pack`),那么你需要根据自己的需要进行调整。
# 创建表格 self.columns = ("69料號", "工單", "領板數量", "待測數量", "待裁數量", "待送修數量", "實際數量", "差異", "盤點人", "確認者") self.tree = ttk.Treeview(self, show="headings", columns=self.columns) for col in self.columns: self.tree.heading(col, text=col) self.tree.grid(row=0, column=2, rowspan=3) # 创建“确定”按钮和确认者名字文本框 self.confirm_person = tk.StringVar() tk.Label(self, text="确认者:").grid(row=7, column=2) tk.Entry(self, textvariable=self.confirm_person).grid(row=7, column=3) tk.Button(self, text="确定", command=self.confirm_inventory).grid(row=8, column=2, columnspan=2)修改這個表格列太寬了
好的,如果您想要修改表格列的宽度,可以使用Treeview的column方法,例如:
```
self.tree.column("69料號", width=100)
self.tree.column("工單", width=100)
self.tree.column("領板數量", width=100)
self.tree.column("待測數量", width=100)
self.tree.column("待裁數量", width=100)
self.tree.column("待送修數量", width=100)
self.tree.column("實際數量", width=100)
self.tree.column("差異", width=100)
self.tree.column("盤點人", width=100)
self.tree.column("確認者", width=100)
```
以上代码将每列的宽度设置为100个像素。您可以根据需要调整宽度大小。
阅读全文