menubar.add_cascade(label="文件", menu=file_menu)怎么修改背景颜色
时间: 2024-03-14 16:47:03 浏览: 63
你可以使用 Tkinter 中的样式配置来修改菜单项的背景颜色。具体步骤如下:
1. 在创建菜单栏的代码后面添加如下代码,创建一个样式配置:
```
self.root.option_add('*Menu.background', 'blue')
```
2. 将上面代码中的 "blue" 替换为你想要使用的颜色名称或颜色代码。
3. 运行代码,你会发现 "文件" 菜单项的背景颜色已经被修改为你指定的颜色。如果你想修改其他菜单项的颜色,只需要将上面代码中的 "*Menu" 替换为对应的菜单项名称即可。例如,如果你想修改 "添加" 菜单项的背景颜色,可以使用以下代码:
```
self.root.option_add('*add.background', 'red')
```
相关问题
class ExcelApp: def init(self, master): self.master = master master.title("Excel App") # 创建菜单栏 menubar = tk.Menu(master) master.config(menu=menubar) # 创建文件菜单及其子菜单 filemenu = tk.Menu(menubar, tearoff=0) filemenu.add_command(label="PA綫點檢表", command=lambda: self.load_excel("D:\點檢系統存放資料夾\點檢明細\點檢内容明細.xlsx")) filemenu.add_command(label="Excel 2", command=lambda: self.load_excel("excel2.xlsx")) filemenu.add_command(label="Excel 3", command=lambda: self.load_excel("excel3.xlsx")) menubar.add_cascade(label="文件", menu=filemenu) # 创建帮助菜单及其子菜单 helpmenu = tk.Menu(menubar, tearoff=0) helpmenu.add_command(label="关于", command=self.show_about) menubar.add_cascade(label="帮助", menu=helpmenu) # 创建工具栏 toolbar = tk.Frame(master, height=30) tk.Button(toolbar, text="打开", command=self.open_file).pack(side=tk.LEFT, padx=2, pady=2) tk.Button(toolbar, text="保存", command=self.save_to_excel).pack(side=tk.LEFT, padx=2, pady=2) toolbar.pack(side=tk.TOP, fill=tk.X) # 创建左侧面板 self.panel_left = tk.Frame(master, width=150, bg='lightcyan') self.panel_left.pack(side=tk.LEFT, fill=tk.Y) # 创建右侧面板 self.panel_right = tk.Frame(master) self.panel_right.pack(side=tk.LEFT, fill=tk.BOTH, expand=True) # 创建Frame来包含标签和下拉框 input_frame = tk.Frame(self.panel_right) input_frame.pack(side=tk.TOP, fill=tk.X, padx=5, pady=5) # 创建标签和下拉框 ri = datetime.datetime.now().strftime('%Y/%m/%d') ri1 = datetime.datetime.now().strftime('%H:%M:%S') self.label1 = tk.Label(input_frame, text="點檢日期") self.label1.pack(side=tk.LEFT, padx=2, pady=2) self.combobox1 = tk.ttk.Combobox(input_frame, values=[ri]) self.combobox1.pack(side=tk.LEFT, padx=2, pady=2) self.combobox1.current(0) self.label2 = tk.Label(input_frame, text="點檢時間") self.label2.pack(side=tk.LEFT, padx=2, pady=2) self.combobox2 = tk.ttk.Combobox(input_frame, values=[ri1]) self.combobox2.pack(side=tk.LEFT, padx=2, pady=2) self.combobox2.current(0)在這段代碼中需要在self.combobox2輸入實時跟新的時間
你可以使用 `after()` 方法来实现定时更新时间,例如每秒更新一次。具体实现方法如下:
1. 定义一个方法 `update_time`,用于更新时间和更新 Combobox 中的值。
```python
def update_time(self):
now = datetime.datetime.now()
date_str = now.strftime('%Y/%m/%d')
time_str = now.strftime('%H:%M:%S')
self.combobox1.configure(values=[date_str])
self.combobox1.current(0)
self.combobox2.configure(values=[time_str])
self.combobox2.current(0)
self.master.after(1000, self.update_time) # 每秒更新一次
```
2. 在 `__init__()` 方法中,调用 `update_time` 方法,启动时间更新。
```python
def __init__(self, master):
# ...
self.update_time() # 启动时间更新
```
注意,这里使用了 `self.master.after(1000, self.update_time)` 来实现定时更新。其中,`self.master` 是主窗口对象,`after()` 方法的第一个参数表示等待的时间(毫秒),第二个参数是要执行的方法。因此,上述代码表示每隔 1000 毫秒(即 1 秒),调用一次 `update_time` 方法,实现时间的更新。
class ExcelApp: def init(self, master): self.master = master master.title("Excel App") # 获取屏幕的宽度和高度 screen_width = master.winfo_screenwidth() screen_height = master.winfo_screenheight() # 将窗口的大小设置为屏幕的大小 master.geometry("%dx%d" % (screen_width, screen_height)) # 创建菜单栏 menubar = tk.Menu(master) master.config(menu=menubar) # 创建文件菜单及其子菜单 filemenu = tk.Menu(menubar, tearoff=0) filemenu.add_command(label="PA綫", command=lambda: self.load_excel("D:\點檢系統存放資料夾\點檢明細\點檢内容明細.xlsx", "PA綫")) filemenu.add_command(label="PB綫", command=lambda: self.load_excel("D:\點檢系統存放資料夾\點檢明細\點檢内容明細.xlsx", "PB綫")) filemenu.add_command(label="Excel 3", command=lambda: self.load_excel("excel3.xlsx")) menubar.add_cascade(label="點檢綫別", menu=filemenu) # 创建帮助菜单及其子菜单 helpmenu = tk.Menu(menubar, tearoff=0) helpmenu.add_command(label="关于", command=self.show_about) menubar.add_cascade(label="帮助", menu=helpmenu) # 创建工具栏 toolbar = tk.Frame(master, height=30) tk.Button(toolbar, text="打开", command=lambda: QueryWindow(tk.Toplevel(root))).pack(side=tk.LEFT, padx=2, pady=2) tk.Button(toolbar, text="保存", command=self.save_to_excel).pack(side=tk.LEFT, padx=2, pady=2) toolbar.pack(side=tk.TOP, fill=tk.X) # 创建左侧面板 self.panel_left = tk.Frame(master, width=150, bg='lightcyan') self.panel_left.pack(side=tk.LEFT, fill=tk.Y) # 创建右侧面板 self.panel_right = tk.Frame(master) self.panel_right.pack(side=tk.LEFT, fill=tk.BOTH, expand=True)根據這個代碼儅用戶點擊打開按鈕時將打開一個新的窗口,在新的窗口可以根據日期,綫別查詢一個txt中相應數據内容,在添加一個可以下載按鈕,將用戶查詢的信息導入出來的代碼
以下是一个简单的代码示例,可以实现你想要的功能:
```python
import tkinter as tk
from tkinter import filedialog
class QueryWindow:
def __init__(self, master):
self.master = master
master.title("查询")
# 添加日期、线别输入框
tk.Label(master, text="日期:").grid(row=0, column=0, padx=5, pady=5)
self.date_entry = tk.Entry(master)
self.date_entry.grid(row=0, column=1, padx=5, pady=5)
tk.Label(master, text="线别:").grid(row=1, column=0, padx=5, pady=5)
self.line_entry = tk.Entry(master)
self.line_entry.grid(row=1, column=1, padx=5, pady=5)
# 添加查询按钮
tk.Button(master, text="查询", command=self.query).grid(row=2, column=0, columnspan=2, padx=5, pady=5)
# 添加下载按钮
tk.Button(master, text="下载", command=self.download).grid(row=3, column=0, columnspan=2, padx=5, pady=5)
def query(self):
# 获取日期、线别输入框中的内容
date = self.date_entry.get()
line = self.line_entry.get()
# 打开要查询的txt文件
file_path = filedialog.askopenfilename(title="选择要查询的文件", filetypes=(("Text files", "*.txt"),))
with open(file_path, "r") as f:
# 遍历文件内容,查找符合条件的行
result = []
for line in f:
if date in line and line.startswith(line):
result.append(line)
# 将查询结果显示在文本框中
self.textbox.delete("1.0", tk.END)
self.textbox.insert(tk.END, "\n".join(result))
def download(self):
# 获取查询结果
result = self.textbox.get("1.0", tk.END)
# 弹出文件保存对话框,将查询结果保存为txt文件
file_path = filedialog.asksaveasfilename(title="保存文件", defaultextension=".txt", filetypes=(("Text files", "*.txt"),))
with open(file_path, "w") as f:
f.write(result)
# 关闭窗口
self.master.destroy()
class ExcelApp:
def __init__(self, master):
self.master = master
master.title("Excel App")
# 获取屏幕的宽度和高度
screen_width = master.winfo_screenwidth()
screen_height = master.winfo_screenheight()
# 将窗口的大小设置为屏幕的大小
master.geometry("%dx%d" % (screen_width, screen_height))
# 创建菜单栏
menubar = tk.Menu(master)
master.config(menu=menubar)
# 创建文件菜单及其子菜单
filemenu = tk.Menu(menubar, tearoff=0)
filemenu.add_command(label="PA綫", command=lambda: self.load_excel("D:\點檢系統存放資料夾\點檢明細\點檢内容明細.xlsx", "PA綫"))
filemenu.add_command(label="PB綫", command=lambda: self.load_excel("D:\點檢系統存放資料夾\點檢明細\點檢内容明細.xlsx", "PB綫"))
filemenu.add_command(label="Excel 3", command=lambda: self.load_excel("excel3.xlsx"))
menubar.add_cascade(label="點檢綫別", menu=filemenu)
# 创建帮助菜单及其子菜单
helpmenu = tk.Menu(menubar, tearoff=0)
helpmenu.add_command(label="关于", command=self.show_about)
menubar.add_cascade(label="帮助", menu=helpmenu)
# 创建工具栏
toolbar = tk.Frame(master, height=30)
tk.Button(toolbar, text="打开", command=lambda: QueryWindow(tk.Toplevel(root))).pack(side=tk.LEFT, padx=2, pady=2)
tk.Button(toolbar, text="保存", command=self.save_to_excel).pack(side=tk.LEFT, padx=2, pady=2)
toolbar.pack(side=tk.TOP, fill=tk.X)
# 创建左侧面板
self.panel_left = tk.Frame(master, width=150, bg='lightcyan')
self.panel_left.pack(side=tk.LEFT, fill=tk.Y)
# 创建右侧面板
self.panel_right = tk.Frame(master)
self.panel_right.pack(side=tk.LEFT, fill=tk.BOTH, expand=True)
def load_excel(self, file_path, sheet_name=None):
pass
def show_about(self):
pass
def save_to_excel(self):
pass
root = tk.Tk()
app = ExcelApp(root)
root.mainloop()
```
注意,这只是一个简单的代码示例,你需要根据你的具体需求进行修改和完善。
阅读全文
相关推荐













