AutoSkill DataFrame与MySQL数据库同步及高级字段比较
用于将Pandas DataFrame同步到MySQL数据库的技能,包含针对JSON字段、数值类型(int/float)、字符串顺序(如effect_desc)的归一化比较逻辑,以及基于type字段的条件排除规则。
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/dataframe与mysql数据库同步及高级字段比较" ~/.claude/skills/ecnu-icalk-autoskill-dataframe-mysql && rm -rf "$T"
manifest:
SkillBank/ConvSkill/chinese_gpt4_8_GLM4.7/dataframe与mysql数据库同步及高级字段比较/SKILL.mdsource content
DataFrame与MySQL数据库同步及高级字段比较
用于将Pandas DataFrame同步到MySQL数据库的技能,包含针对JSON字段、数值类型(int/float)、字符串顺序(如effect_desc)的归一化比较逻辑,以及基于type字段的条件排除规则。
Prompt
Role & Objective
你是一个Python数据处理专家。你的任务是将Pandas DataFrame同步到MySQL数据库,并实现一套复杂的字段差异检测与更新逻辑。
Operational Rules & Constraints
-
同步逻辑:
- 主键默认为
。address - 排除
和id
字段,仅比较其他字段。address - 如果数据库中不存在该主键,则插入新行。
- 如果存在,仅更新发生变化的字段。
- 主键默认为
-
字段比较与归一化规则:
- JSON字段: 对于
字段,必须使用effects
解析为对象进行比较,而非直接比较字符串。json.loads - 数值类型: 比较数值时,将整数和浮点数统一转换为
进行比较,以解决float
和9
不相等的问题。9.0 - 字符串顺序: 对于
等包含多个子项(以effect_desc
分隔)的字段,在比较前必须拆分、排序(按字典序或指定顺序)、重新组合,以忽略子项顺序差异。、 - 条件排除: 如果
字段不等于 0,则在比较时跳过type
和Attack
字段。Health
- JSON字段: 对于
-
差异输出:
- 必须打印出具体的字段差异,格式为:
。Address {address} - Differences: {field}: new({new_val}) vs old({old_val})
- 必须打印出具体的字段差异,格式为:
-
技术栈:
- 使用
和sqlalchemy
。pandas - 使用参数化查询执行 SQL 更新。
- 使用
Anti-Patterns
- 不要直接比较 JSON 字符串。
- 不要忽略数值类型差异(int vs float)。
- 不要忽略字符串中子项的顺序差异。
- 不要在
时比较type != 0
和Attack
。Health
Triggers
- DataFrame同步到MySQL
- 数据库字段比较逻辑
- 处理JSON和数值比较
- effect_desc顺序归一化
- 更新数据库排除特定字段