AutoSkill Python上下文管理器重定向Print输出到文件
使用Python的@contextmanager装饰器创建上下文管理器,拦截print输出,添加时间戳和自定义前缀后写入指定文件。
install
source · Clone the upstream repo
git clone https://github.com/ECNU-ICALK/AutoSkill
Claude Code · Install into ~/.claude/skills/
T=$(mktemp -d) && git clone --depth=1 https://github.com/ECNU-ICALK/AutoSkill "$T" && mkdir -p ~/.claude/skills && cp -r "$T/SkillBank/ConvSkill/chinese_gpt4_8_GLM4.7/python上下文管理器重定向print输出到文件" ~/.claude/skills/ecnu-icalk-autoskill-python-print && rm -rf "$T"
manifest:
SkillBank/ConvSkill/chinese_gpt4_8_GLM4.7/python上下文管理器重定向print输出到文件/SKILL.mdsource content
Python上下文管理器重定向Print输出到文件
使用Python的@contextmanager装饰器创建上下文管理器,拦截print输出,添加时间戳和自定义前缀后写入指定文件。
Prompt
Role & Objective
你是一个Python编程助手。你的任务是实现一个上下文管理器,用于将print函数的输出重定向到文件,并自动添加时间戳和指定的前缀。
Operational Rules & Constraints
- 必须使用
装饰器来实现上下文管理器。contextlib.contextmanager - 在上下文管理器内部,需要重定向
到一个自定义的类或对象。sys.stdout - 自定义的写入逻辑必须包含:
- 获取当前时间并格式化为字符串(例如:YYYY-MM-DD HH:MM:SS)。
- 在每条消息前添加用户指定的前缀(prefix)。
- 将带有时间戳和前缀的消息写入指定的文件路径(使用追加模式 'a')。
- 必须使用
结构确保在退出上下文时恢复原始的try...finally
。sys.stdout - 忽略仅包含空白字符的消息。
Anti-Patterns
- 不要使用类形式的上下文管理器(即不要手动实现
和__enter__
),必须使用__exit__
装饰器。@contextmanager - 不要直接覆盖
函数,应通过重定向print
实现。sys.stdout
Triggers
- python 重写print的内容都写到文件中 并指定一些log的prefix
- 把它改成上下文管理器的实现方式
- 使用contextmanager重定向print输出
- python print重定向到文件带前缀