mirror of
https://github.com/openclaw/openclaw.git
synced 2026-03-13 11:00:50 +00:00
What: switch to 你/你的 tone; standardize Skills/Gateway网关/local loopback/私信 wording Why: align zh-CN docs with issue 6995 feedback + idiomatic tech style Tests: pnpm docs:build
130 lines
3.7 KiB
Markdown
130 lines
3.7 KiB
Markdown
---
|
||
read_when:
|
||
- 你正在更改向模型或用户展示时间戳的方式
|
||
- 你正在调试消息或系统提示词输出中的时间格式问题
|
||
summary: 信封、提示词、工具和连接器中的日期与时间处理
|
||
title: 日期与时间
|
||
x-i18n:
|
||
generated_at: "2026-02-01T20:24:52Z"
|
||
model: claude-opus-4-5
|
||
provider: pi
|
||
source_hash: 753af5946a006215d6af2467fa478f3abb42b1dff027cf85d5dc4c7ba4b58d39
|
||
source_path: date-time.md
|
||
workflow: 14
|
||
---
|
||
|
||
# 日期与时间
|
||
|
||
OpenClaw 默认使用**主机本地时间作为传输时间戳**,并且**仅在系统提示词中使用用户时区**。
|
||
提供商时间戳会被保留,因此工具保持其原生语义(当前时间可通过 `session_status` 获取)。
|
||
|
||
## 消息信封(默认为本地时间)
|
||
|
||
入站消息会附带一个时间戳(分钟精度):
|
||
|
||
```
|
||
[Provider ... 2026-01-05 16:26 PST] message text
|
||
```
|
||
|
||
此信封时间戳**默认为主机本地时间**,与提供商时区无关。
|
||
|
||
你可以覆盖此行为:
|
||
|
||
```json5
|
||
{
|
||
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
|
||
```
|
||
|
||
## 系统提示词:当前日期与时间
|
||
|
||
如果已知用户时区,系统提示词会包含一个专门的**当前日期与时间**部分,其中仅包含**时区**(不含时钟/时间格式),以保持提示词缓存的稳定性:
|
||
|
||
```
|
||
Time zone: America/Chicago
|
||
```
|
||
|
||
当智能体需要获取当前时间时,请使用 `session_status` 工具;状态卡中包含时间戳行。
|
||
|
||
## 系统事件行(默认为本地时间)
|
||
|
||
插入到智能体上下文中的排队系统事件会带有时间戳前缀,使用与消息信封相同的时区选择(默认:主机本地时间)。
|
||
|
||
```
|
||
System: [2026-01-12 12:19:17 PST] Model switched.
|
||
```
|
||
|
||
### 配置用户时区和格式
|
||
|
||
```json5
|
||
{
|
||
agents: {
|
||
defaults: {
|
||
userTimezone: "America/Chicago",
|
||
timeFormat: "auto", // auto | 12 | 24
|
||
},
|
||
},
|
||
}
|
||
```
|
||
|
||
- `userTimezone` 设置提示词上下文中的**用户本地时区**。
|
||
- `timeFormat` 控制提示词中的 **12 小时/24 小时显示格式**。`auto` 跟随操作系统偏好设置。
|
||
|
||
## 时间格式检测(auto)
|
||
|
||
当 `timeFormat: "auto"` 时,OpenClaw 会检查操作系统偏好设置(macOS/Windows),并回退到区域格式。检测到的值会**按进程缓存**,以避免重复的系统调用。
|
||
|
||
## 工具载荷 + 连接器(原始提供商时间 + 标准化字段)
|
||
|
||
渠道工具返回**提供商原生时间戳**,并添加标准化字段以保持一致性:
|
||
|
||
- `timestampMs`:纪元毫秒数(UTC)
|
||
- `timestampUtc`:ISO 8601 UTC 字符串
|
||
|
||
原始提供商字段会被保留,不会丢失任何数据。
|
||
|
||
- Slack:来自 API 的类纪元字符串
|
||
- Discord:UTC ISO 时间戳
|
||
- Telegram/WhatsApp:提供商特定的数字/ISO 时间戳
|
||
|
||
如果需要本地时间,请使用已知时区在下游进行转换。
|
||
|
||
## 相关文档
|
||
|
||
- [系统提示词](/concepts/system-prompt)
|
||
- [时区](/concepts/timezone)
|
||
- [消息](/concepts/messages)
|