Alter.Org.UA
 << Back Home EN en   Donate Donate

Automated KiCad7 Symbol generation tool

make_kicad_sym.py форму╓ symbol-файл для KiCad7 на основ╕ спрощеного опису п╕н╕в елемента.

Опис формату вх╕дного файлу

Назва Компоненту
  • Ключове слово: name:
  • Приклад: name: ESP32-WT32-S1
  • Опис: Визнача╓ назву компонента.
Властивост╕
  • Ключове слово: prop:
  • Приклад: prop: Reference U
  • Опис: Встановлю╓ р╕зноман╕тн╕ властивост╕, так╕ як посилання, в╕дбиток, посилання на техн╕чн╕ умови, ключов╕ слова та опис.
Розм╕р Шрифту
  • Ключове слово: font:
  • Приклад: font: 1.27
  • Опис: Вказу╓ розм╕р шрифту для представлення компонента.
Розм╕р Кроку
  • Ключове слово: step:
  • Приклад: step: 2.45
  • Опис: Визнача╓ розм╕р кроку для розрахунку позиц╕й п╕н╕в.
Розм╕р Компоненту
  • Ключове слово: sizep:
  • Приклад: sizep: 17 17
  • Опис: Вказу╓ ширину та висоту компонента, розрахован╕ на основ╕ розм╕ру кроку.
Розм╕щення П╕н╕в та Конф╕гурац╕я
  • Ключов╕ слова: side:, [Назва П╕на] [Тип П╕на]
  • Приклади: side: L, GPIO36 i
  • Опис: Встановлю╓ сторону для визначення п╕н╕в та визнача╓ кожен п╕н з його назвою та типом.
Пряме Нумерування
  • Ключове слово: num:
  • Приклад: num: 1
  • Опис: Перезапуска╓ нумерац╕ю п╕н╕в з вказаного номера, зб╕льшуючи для кожного наступного п╕на.
Зворотн╓ Нумерування
  • Ключове слово: rnum:
  • Приклад: rnum: 31
  • Опис: Перезапуска╓ нумерац╕ю п╕н╕в з вказаного номера, зменшуючи для кожного наступного п╕на.
Пропускання Позиц╕й
  • Ключове слово: --
  • Опис: Пропуска╓ одну позиц╕ю без впливу на нумерац╕ю.
Типи П╕н╕в

Типи п╕н╕в можуть бути як ключовими словами KiCad, такими як 'input', 'output', 'bidirectional' тощо, так ╕ скороченнями:

  • i для входу
  • o для виходу
  • io для двонаправленого
  • vin для входу живлення (також v)
  • n для пасивного (також -)
  • vout для виходу живлення

  • для не п╕дключеного
Розм╕щення

П╕ни розм╕щуються посл╕довно зверху вниз ╕ зл╕ва направо, в╕дпов╕дно до порядку ╖х визначення в сец╕╖ кожно╖ сторони side:

Якщо знайдено б╕льше одного запису з тим же ID, xlf_merge врахову╓ стан перекладу (див. нижче пр╕оритет об'╓днання) та використову╓ запис з найвищим пр╕оритетом. Якщо записи мають однаковий пр╕оритет, використову╓ться 1-й, якщо не вказано -f.

Example esp32-wt32-s1.sym.in

name: ESP32-WT32-S1

prop: Reference U
prop: Footprint RF_Module:ESP32-WT32-S1
prop: Datasheet https://datasheet.lcsc.com/lcsc/2001060933_Wireless-tag-WT32-S1_C477832.pdf
prop: ki_keywords RF Radio BT ESP ESP32 Espressif Ethernet external U.FL antenna
prop: ki_description RF Module, ESP32-D0WD SoC, Wi-Fi 802.11b/g/n, Bluetooth, BLE, Ethernet RMII, 32-bit, 2.7-3.6V, PCB antenna, SMD
prop: ki_fp_filters ESP32?WT32?S1*

font: 1.27
step: 2.54
sizep: 12 12

side: L
EN  input
GPIO36  i
GPIO38  i
GPIO39  i
GPIO34  i

GPIO37  i
GPIO35  i
GPIO32  i
GPIO33  i

GPIO25  io
GPIO26  io

side: B
--
--
GPIO27  io
GPIO14  io
GPIO12  io
GPIO13  io

GPIO15  io
GPIO2  io
GPIO0  io
GPIO4  io

GPIO16  io

side: R
rnum: 31
GND -
GPIO21  io
U0TX/GPIO1 io
U0RX/GPIO3 io

GPIO22  io
GPIO19  io
GPIO23  io
GPIO18  io

GPIO5  io
GPIO17  io
VDD  vin

Usage

python kicad_symbol_generator.py <input_file> > <output_file.kicad_sym>
    or
python kicad_symbol_generator.py <input_file> <output_file.csv>

Demo




https://github.com/Alter-1/make_kicad_sym

Download: make_kicad_sym.py, use Python 3.x


2024.01.27


FB or mail alterX@alter.org.ua (remove X)   Share
Автор: Alter (Александр А. Телятников) Сервер: Apache+PHP под FBSD © 2002-2025