Go简易记账应用首选内存+文件持久化方案:用Record结构体和全局切片管理数据,通过json序列化实现data.json读写;HTTP服务用net/http手写REST路由,避免SQLite/GORM等过度设计。
Go 语言本身不内置 GUI 或 Web 框架,所谓“简易记账应用”在 Golang 中通常指命令行 CLI 工具或轻量 HTTP 服务。直接用 fmt + os.Args 或 net/http + 内存/文件存储就能跑起来,无需第三方框架。
map 和 slice 在内存中实现增删改查适合快速验证逻辑、学习 Go 基础语法。所有数据存在内存里,程序退出即丢失。
Record 结构体至少包含 ID(int 自增)、Type("income" 或 "expense")、Amount(float64)、Remark(string)、CreatedAt(time.Time)var records []Record 存储,var nextID int = 1 管理 IDrecords,更新 nextID
records[:i] = append(records[:i], records[i+1:]...) 原地切片删除(注意索引越界)records,用 strings.Contains 匹配 Remark,或按 Type 过滤type Record struct {
ID int `json:"id"`
Type string `json:"type"`
Amount float64 `json:"amount"`
Remark string `json:"remark"`
CreatedAt time.Time `json:"created_at"`
}
var records []Record
var nextID = 1
func CreateRecord(t, r string, a float64) {
records = append(records, Record{
ID: nextID,
Type: t,
Amount: a,
Remark: r,
CreatedAt: time.Now(),
})
nextID++
}
encoding/json 把数据持久化到文件避免每次重启清空数据,是最小可行的“落地”方案。注意并发写入会出错,CLI 场景单进程可忽略。
os.ReadFile("data.json") → json.Unmarshal 到 []Record
json.MarshalIndent 格式化,再 os.WriteFile 覆盖原文件data.json 不存在?os.IsNotExist(err) 捕获后初始化空切片即可os.OpenFile(..., os.O_APPEND) 追加 JSON —— JSON 不支持流式追加,必须全量重写net/http 搭一个 REST 风格的记账 API比 CLI 更易测试和集成,浏览器访问 http://localhost:8080/records 就能看到所有记录,用 curl 发送 POST 即可新增。
http.HandleFunc 手写分发:/records(GET/POST)、/records/{id}(GET/DELETE)strings.TrimPrefix(r.URL.Path, "/records/") 后再 strconv.Atoi
w.Header().Set("Content-Type", "application/json")
io.ReadAll(r.Body) → json.Unmarshal,别忘了 defer r.Body.Close()
w.WriteHeader(http.StatusNotFound)
对“简易记账”而言,引入 github.com/mattn/go-sqlite3 或 gorm.io/gorm 是过度设计。你会立刻陷入驱动注册、DSN 配置、Migrate 表结构、事务控制等非核心问题中。
AutoMigrate 会在首次运行时建表,但你只是想记几笔早餐花了多少钱boltdb 或 bbolt 也远超需求 —— 它们面向高并发键值场景,不是为 CSV 级记账设计的真正该警惕的是:别在 main.go 里堆砌所有逻辑。把数据操作封装进 record.go,HTTP 路由收口在 handler.go,哪怕只有三四个函数,结构清晰了,后续加导出 CSV、按月统计才不会崩。