日期与时间
OpenClaw 默认对传输时间戳使用主机本地时间,在系统 Prompt 中仅使用用户时区。
Provider 时间戳会被保留,这样工具能保持原生语义(当前时间可通过 session_status 获取)。
消息封装(默认使用本地时间)
入站消息会被包装上时间戳(精确到分钟):
[Provider ... 2026-01-05 16:26 PST] message text
这个封装时间戳默认使用主机本地时间,不受 Provider 时区影响。
你可以覆盖这个行为:
{
agents: {
defaults: {
envelopeTimezone: "local", // "utc" | "local" | "user" | IANA 时区
envelopeTimestamp: "on", // "on" | "off"
envelopeElapsed: "on", // "on" | "off"
},
},
}
envelopeTimezone: "utc"使用 UTC 时间。envelopeTimezone: "local"使用主机时区。envelopeTimezone: "user"使用agents.defaults.userTimezone(回退到主机时区)。- 使用明确的 IANA 时区(如
"America/Chicago")来固定时区。 envelopeTimestamp: "off"从封装头部移除绝对时间戳。envelopeElapsed: "off"移除经过时间后缀(+2m这种样式)。
示例
本地时间(默认):
[WhatsApp +1555 2026-01-18 00:19 PST] hello
用户时区:
[WhatsApp +1555 2026-01-18 00:19 CST] hello
启用经过时间:
[WhatsApp +1555 +30s 2026-01-18T05:19Z] follow-up
系统 Prompt:当前日期与时间
如果已知用户时区,系统 Prompt 会包含一个专门的当前日期与时间部分,其中仅包含时区(不含时钟/时间格式),以保持 Prompt 缓存稳定:
Time zone: America/Chicago
当 Agent 需要当前时间时,使用 session_status 工具;状态卡片中包含时间戳行。
系统事件行(默认使用本地时间)
插入到 Agent Context 中的排队系统事件会带有时间戳前缀,使用与消息封装相同的时区选择(默认:主机本地时间)。
System: [2026-01-12 12:19:17 PST] Model switched.
配置用户时区和格式
{
agents: {
defaults: {
userTimezone: "America/Chicago",
timeFormat: "auto", // auto | 12 | 24
},
},
}
userTimezone设置 Prompt Context 的用户本地时区。timeFormat控制 Prompt 中的 12 小时/24 小时显示。auto会跟随操作系统偏好。
时间格式检测(自动)
当 timeFormat: "auto" 时,OpenClaw 会检查操作系统偏好(macOS/Windows),并回退到区域格式。检测到的值会按进程缓存,以避免重复的系统调用。
工具负载和连接器(原始 Provider 时间 + 标准化字段)
Channel 工具返回 Provider 原生时间戳,并添加标准化字段以保持一致性:
timestampMs:纪元毫秒数(UTC)timestampUtc:ISO 8601 UTC 字符串
原始 Provider 字段会被保留,不会丢失任何信息。
- Slack:来自 API 的类纪元字符串
- Discord:UTC ISO 时间戳
- Telegram/WhatsApp:Provider 特定的数字/ISO 时间戳
如果你需要本地时间,使用已知时区在下游进行转换。