Turn natural-language life logs into durable records. This skill classifies each input item, generates tags, creates user-visible markdown, writes to a daily note under life/daily, and syncs structured data into life/db/life.db.
Use these paths unless the user explicitly overrides them:
life/
daily/
ideas/
db/life.db
Create missing directories as needed. Never delete existing content. Append or update only.
Map every parsed item to exactly one primary type:
expense: spending, bills, purchases, subscriptions, refundstask: completed tasks, ongoing work, todos, chores, habitsschedule: calendar items, appointments, time blocks, plansidea: ideas, inspiration, possible projects, reflections worth savingWhen a sentence contains multiple items, split it into multiple records.
For each user request:
id for each record using the pattern:exp_YYYYMMDD_NNNtask_YYYYMMDD_NNNsched_YYYYMMDD_NNNidea_YYYYMMDD_NNNscripts/process_entry.py.Always keep the original user wording in raw_text. Never invent missing fields. Leave unknown fields null.
Because this skill is configured for visible output, show a concise but complete result after writing:
## 已整理记录
### 1) <type label>
- ID: <id>
- 标签: #a #b
- 归档: <daily markdown path>
- 数据库: <written/skipped>
#### Markdown
<the markdown block written for this item>
#### JSON
If there are multiple records, repeat the block for each one.
Use scripts/parse_entries.py for natural-language parsing. The parser now reads configurable rules from references/parser_config.json, so prefer editing that file instead of changing Python when you need new categories, tags, or keyword mappings.
Extract when present:
amountcurrency (default CNY only when the currency symbol or language implies RMB; otherwise null)categorysubcategorymerchantpay_methodDefault top-level tags often include 开销 plus one semantic tag such as 餐饮 or 交通.
Preferred categories:
Extract when present:
status (todo, doing, done, cancelled)priority (low, normal, high)projectdue_datecompleted_atIf the user says they already did something, default status to done.
Extract when present:
schedule_datestart_timeend_timelocationstatus (planned, done, skipped)If the user uses relative dates, resolve them from the current conversation date. Prefer passing --today YYYY-MM-DD to scripts/process_entry.py or scripts/parse_entries.py so relative dates like 明天 are stable across environments.
Extract when present:
idea_typestatus (captured, reviewing, used, archived)related_task_idDefault status to captured.
Before editing Python, check whether the change can be made in references/parser_config.json.
You can change:
To test a modified config without changing the bundled default file:
python scripts/parse_entries.py --config /path/to/custom_config.json --text "买咖啡 18 元,明天下午两点去体检"
Write each record into the daily note for its effective date under one of these sections:
## 开销## 任务## 日程## 灵感Use this block structure:
### <id>
- 时间:<time or empty>
- 标签:#tag1 #tag2
- 原始描述:<raw_text>
- 摘要:<summary>
Then add type-specific fields:
Use this when the user provides natural language and wants the records saved immediately:
python scripts/process_entry.py --root life --db life/db/life.db --today 2026-03-10 --text "今天中午牛肉面 26 元,下午整理了书桌,想到可以做一个生活数据看板"
The wrapper script will:
{"records": [...]} with scripts/parse_entries.pyscripts/save_entry.pyUse this when the user asks to inspect or verify the structured output before writing:
python scripts/parse_entries.py --text "明天下午两点去体检,买咖啡 18 元"
Then save:
python scripts/save_entry.py --root life --db life/db/life.db --stdin-json
Use this once before first write if life/db/life.db does not exist and you are not using process_entry.py:
python scripts/init_db.py --db life/db/life.db
The database design is:
entriesexpensestasksschedulesideastagsentry_tagsSee references/schema.md for the schema, references/examples.md for sample payloads and commands, and references/configuration.md plus references/parser_config.json for configurable parsing rules.
共 1 个版本