共计 1789 个字符,预计需要花费 5 分钟才能阅读完成。
一、金百泽 Skill 工具是什么?
金百泽 Skill 工具是 Cadence Allegro 平台上专用的脚本语言(PCB 设计领域的 ” 自动化助手 ”),就像 Excel 里的 VBA。它能通过代码批量操作设计软件,把原本需要手动点击几十次的操作变成一键运行。我刚入行时,眼睁睁看着同事用 Skill 脚本 10 分钟干完我半天的工作量——这就是学习它的最大动力。

二、为什么 PCB 设计师需要学 Skill?
- 图形界面效率瓶颈:铺铜皮修尖角时,鼠标操作精度远不如代码控制坐标
- 重复劳动陷阱:给 500 个电阻重命名位号,手动修改极易出错
- DRC 检查痛点:深夜加班改设计规则,全靠肉眼找违规点太崩溃
三、手把手环境配置
- 版本确认:Allegro 17.4+(建议用金百泽提供的企业定制版)
- 脚本存放 :将.il 文件放在
C:/Cadence/SPB_17.4/share/local/pcb/skill目录 - 加载测试:在 Allegro 命令行输入
load("你的脚本.il")不报错即成功
注:遇到 ”E- Error toplevel: undefined function” 错误,通常是路径或版本问题
四、3 大核心语法精讲
1. 列表操作(就像 PCB 上的元件表)
; 创建元件列表
compList = axlDBGetDesign()->components
; 筛选 0402 封装的电阻
filteredList = setof(x compList x->name == "RESC1005X40")
2. 循环结构(批量处理的核心)
foreach(comp filteredList
printf("正在处理 %s\n" comp->name)
; 这里写操作代码
)
3. 条件判断(智能 DRC 修复的关键)
if(axlDRCGetCount() > 0 then
axlShell("drc batch")
println("⚠️ 发现 DRC 违规,已自动运行批处理")
)
五、实战代码示例(可直接复用)
案例 1:自动生成元件位号
; 按坐标重排位号(适合布局后整理)procedure(SortRefDes()
comps = axlDBGetDesign()->components
; 按 X 坐标排序
sortedComps = sort(comps 'lessp car axlPolygonCenter(cadr(axlGetAttr(comp'footprintBounds)))))
; 重新编号
cnt = 1
foreach(comp sortedComps
axlRenameComp(comp sprintf(nil "R%%03d" cnt))
cnt++
)
)
案例 2:批量修改线宽(BGA 区域加粗)
; 选中 BGA 区域所有走线
bgaNets = axlGetSelSet(axlSetFindNet("VDD*"))
axlClearSelSet()
foreach(net bgaNets
; 修改线宽到 8mil
axlChangeWidth(net 8.0)
; 高亮修改过的网络
axlHighlightObject(net)
)
六、生产环境避坑指南
- 性能优化
- 循环内避免
axlUIMsgBox弹窗(会打断脚本) -
大数据量操作时用
axlDBTransactionBegin/Commit包裹 -
版本控制
- 使用 Git 管理.il 文件(建议按功能模块分目录)
-
脚本头部添加注释说明:
; 脚本作者:你的名字 ; 最后更新:2024-03-15 ; 功能描述:自动修复 3W 间距 DRC 错误 -
安全规范
- 禁止在脚本中使用
axlShell("shell rm -rf")等危险命令 - 企业环境设置脚本执行权限白名单
七、进阶学习路径
- 官方文档重点章节:
- 《Allegro Skill Language User Guide》第 5 章(函数库详解)
-
《SKILL IDE Debugger Guide》调试技巧
-
调试技巧:
; 注册自定义命令(方便反复调用)axlCmdRegister("mycmd" 'SortRefDes ?cmdType"interactive") -
课后作业:
- 尝试写自动拼板脚本(提示:用
axlDBCreateDrawing和axlDBCreateOutline) - 挑战:实现丝印自动避让焊盘功能
写在最后
记得第一次成功运行自动重编号脚本时,那种解放双手的快乐至今难忘。Skill 就像 PCB 设计师的 ” 魔法杖 ”,初期学习曲线虽陡,但掌握后能成倍提升工作效率。建议从每天解决一个小痛点开始,积累半年后你会发现自己已经能写出惊艳团队的自动化工具。
正文完
发表至: 电子设计自动化
近一天内
