第1眼TV-华龙网讯(曹妤)“小优,我朋友来了,帮我欢迎下。”一声令下,空调送出宜人凉风,暖色调灯光次第亮起,窗帘缓缓打开,营造明亮氛围。在9月5日开...
2025-09-05 0
在 users 表中新增一列 budget,存储每个用户的月度预算(默认 NULL 表示未设置):
ALTER TABLE users ADD COLUMN budget REAL;
在用户登录后界面(BudgetApp)增加一个 “设置预算” 按钮,用户可以输入月度预算金额:
def set_budget(self): """设置月度预算""" budget = simpledialog.askfloat("设置预算", "请输入您的月度预算金额:") if budget is not None and budget > 0: self.cursor.execute("UPDATE users SET budget=? WHERE id=?", (budget, self.user_id)) self.conn.commit() messagebox.showinfo("成功", f"预算已设置为 {budget:.2f}")
在按钮区增加:
tk.Button(frame_btn, text="设置预算", command=self.set_budget).pack(side=tk.LEFT, padx=10)
在新增支出时调用检测逻辑:
def check_budget(self): """检查是否超支""" # 获取当前用户预算 self.cursor.execute("SELECT budget FROM users WHERE id=?", (self.user_id,)) budget = self.cursor.fetchone()[0] if budget is None: return # 未设置预算则跳过 # 计算本月支出 today = datetime.now() start_month = today.replace(day=1).strftime("%Y-%m-%d") self.cursor.execute( "SELECT SUM(amount) FROM records WHERE user_id=? AND type='支出' AND date>=?", (self.user_id, start_month) ) total_expenses = self.cursor.fetchone()[0] or 0 # 判断是否超支 if total_expenses > budget: messagebox.showwarning("预算提醒", f"本月支出 {total_expenses:.2f} 已超出预算 {budget:.2f}!")
然后在 add_record() 方法的末尾调用:
if record_type == "支出": self.check_budget()
相关文章
第1眼TV-华龙网讯(曹妤)“小优,我朋友来了,帮我欢迎下。”一声令下,空调送出宜人凉风,暖色调灯光次第亮起,窗帘缓缓打开,营造明亮氛围。在9月5日开...
2025-09-05 0
现在人们打棋牌麻将谁不想赢?手机微乐麻将必赢神器但是手机棋牌麻将是这么好赢的吗?在手机上打棋牌麻将想赢,不仅需要运气,也需要技巧。掌握的棋牌麻将技巧就...
2025-09-05 0
IT之家 9 月 5 日消息,SEAVIV 希未在推出 AideaBook R14 笔记本电脑后又带来了一款迷你 AI 工作站产品。这一名为 Aide...
2025-09-05 0
您好:这款游戏可以开挂,确实是有挂的,很多玩家在这款游戏中打牌都会发现很多用户的牌特别好,总是好牌,而且好像能看到-人的牌一样。所以很多小伙伴就怀疑这...
2025-09-05 0
稀释制冷机:为量子计算芯片提供接近绝对零度(-273.℃)的超低温环境小型化量子卫星地面站:全球首颗量子科学实验卫星与量子微纳卫星的地面接收端️单光子...
2025-09-05 0
在存储芯片领域,主要产品是两类,一种是NAND闪存,用于长期储数据,比如手机的存储空间,SSD硬盘等。还有一种是DRAM内存(含HBM),这种用于短期...
2025-09-05 0
气动尖峰发动机这东西,说白了就是一种火箭发动机设计,喷管形状像个锥子,能自动适应不同高度的大气压力,不像传统钟形喷管那样只在特定海拔玩得转。德国的波拉...
2025-09-05 0
写在最前显示器作为与用户与交互的外设中最大,也是最重要的配件,是能极大提升游戏、专业领域的工作体验与效率的重要组成部分,也是很多电脑及专业外设厂家不断...
2025-09-05 0
发表评论