python

关注公众号 jb51net

关闭
首页 > 脚本专栏 > python > Python账本应用

Python整合SQLite搭建一个轻量级账本应用

作者:金泽宸

这篇文章为大家详细主要介绍了如何使用Python整合SQLite搭建一个轻量级账本应用,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下

想记账,但不想用冗杂 App?这篇带你用 Python 和 SQLite 快速打造一个能记录收支、统计余额、按月查询的本地账本工具,轻便、够用、可扩展!

本文目标

一、数据库设计

创建一张records表

CREATE TABLE records (
    id INTEGER PRIMARY KEY AUTOINCREMENT,
    type TEXT NOT NULL,        -- 收入 / 支出
    category TEXT NOT NULL,    -- 分类(工资、餐饮、交通等)
    amount REAL NOT NULL,      -- 金额
    note TEXT,                 -- 备注
    date TEXT NOT NULL         -- 日期(YYYY-MM-DD)
)

二、初始化数据库(init_db.py)

import sqlite3

conn = sqlite3.connect("ledger.db")
cursor = conn.cursor()

cursor.execute("""
CREATE TABLE IF NOT EXISTS records (
    id INTEGER PRIMARY KEY AUTOINCREMENT,
    type TEXT NOT NULL,
    category TEXT NOT NULL,
    amount REAL NOT NULL,
    note TEXT,
    date TEXT NOT NULL
)
""")

conn.commit()
conn.close()

print("✅ 数据库初始化完成")

运行一次:

python init_db.py

三、添加收支记录(add.py)

import sqlite3
from datetime import datetime

def add_record():
    rtype = input("类型(收入/支出):")
    category = input("分类(工资/餐饮等):")
    amount = float(input("金额:"))
    note = input("备注(可选):")
    date = input("日期(默认今天,回车跳过):") or datetime.now().strftime("%Y-%m-%d")

    conn = sqlite3.connect("ledger.db")
    cursor = conn.cursor()

    cursor.execute("""
        INSERT INTO records (type, category, amount, note, date)
        VALUES (?, ?, ?, ?, ?)
    """, (rtype, category, amount, note, date))

    conn.commit()
    conn.close()

    print("✅ 记录添加成功")

if __name__ == "__main__":
    add_record()

四、查询总览 & 统计(view.py)

import sqlite3

def list_records():
    conn = sqlite3.connect("ledger.db")
    cursor = conn.cursor()

    cursor.execute("SELECT * FROM records ORDER BY date DESC")
    rows = cursor.fetchall()

    total_income = 0
    total_expense = 0

    for row in rows:
        id, rtype, cat, amt, note, date = row
        print(f"{id}. [{rtype}] {cat} ¥{amt} - {note} ({date})")
        if rtype == "收入":
            total_income += amt
        else:
            total_expense += amt

    balance = total_income - total_expense
    print(f"\n📈 收入总计:¥{total_income:.2f}")
    print(f"📉 支出总计:¥{total_expense:.2f}")
    print(f"💰 当前余额:¥{balance:.2f}")

    conn.close()

if __name__ == "__main__":
    list_records()

五、进阶:按月份或分类过滤查询(filter.py)

import sqlite3

def filter_by_month(month):  # 格式:2025-07
    conn = sqlite3.connect("ledger.db")
    cursor = conn.cursor()

    cursor.execute("""
        SELECT * FROM records WHERE date LIKE ?
        ORDER BY date DESC
    """, (f"{month}%",))

    for row in cursor.fetchall():
        print(row)

    conn.close()

filter_by_month("2025-07")

使用演示

python add.py       # 添加记录
python view.py      # 查看总览
python filter.py    # 按月过滤

拓展挑战

总结

SQLite 是个人项目和轻量应用最值得掌握的数据库,能存、能查、免服务、易扩展,完美适配一切“小而美”场景。

到此这篇关于Python整合SQLite搭建一个轻量级账本应用的文章就介绍到这了,更多相关Python账本应用内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

您可能感兴趣的文章:
阅读全文