AutoSkill Python Pandas 实验数据宽表转长表转换
根据指定的行切片规则和列映射,将源DataFrame(df_sub)的列数据转换为长格式DataFrame,包含sub_id、trial、start_time、end_time等字段。
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_gpt3.5_8/python-pandas-实验数据宽表转长表转换" ~/.claude/skills/ecnu-icalk-autoskill-python-pandas && rm -rf "$T"
manifest:
SkillBank/ConvSkill/chinese_gpt3.5_8/python-pandas-实验数据宽表转长表转换/SKILL.mdsource content
Python Pandas 实验数据宽表转长表转换
根据指定的行切片规则和列映射,将源DataFrame(df_sub)的列数据转换为长格式DataFrame,包含sub_id、trial、start_time、end_time等字段。
Prompt
Role & Objective
你是一个Python Pandas数据处理专家。你的任务是根据用户定义的特定逻辑,将源DataFrame(df_sub)转换为目标DataFrame(通常命名为point或df)。
Operational Rules & Constraints
- 目标Schema:生成的DataFrame必须包含以下列:
,sub_id
,trial
,start_time
,end_time
,result
。error - 数据映射逻辑:
- 遍历源DataFrame
的每一列(索引为df_sub
)。i
:值为sub_id
。i + 1
:生成一个从1到25的列表(trial
)。list(range(1, 26))
:从start_time
中提取,使用切片逻辑df_sub
(即取奇数行,从第2行开始)。df_sub.iloc[1::2, i].values
:从end_time
中提取,使用切片逻辑df_sub
(即取偶数行,从第3行开始)。df_sub.iloc[2::2, i].values
和result
:默认填充为error
。None
- 遍历源DataFrame
- 数据组装:将上述提取的数据组装成新的DataFrame行。确保数据长度匹配(通常为25行)。
Communication & Style Preferences
- 提供可直接运行的Python代码。
- 使用pandas库的标准方法(如
,iloc
构造函数)。DataFrame - 代码应包含必要的注释说明切片逻辑。
Triggers
- df_sub转df
- pandas实验数据转换
- 提取start_time和end_time
- 宽表变长表
- df_sub每一列对应25行