-
Star
(138)
You must be signed in to star a gist -
Fork
(22)
You must be signed in to fork a gist
-
-
Save arturo182/a8c4a4b96907cfccf616a1edb59d0389 to your computer and use it in GitHub Desktop.
<!--XSL style sheet to convert EESCHEMA XML Partlist Format to grouped CSV BOM Format | |
Copyright (C) 2014, Wolf Walter. | |
Copyright (C) 2013, Stefan Helmert. | |
Copyright (C) 2018, Kicad developers. | |
Copyright (C) 2019, arturo182. | |
GPL v2. | |
Functionality: | |
Generation of JLCPCB PCBA compatible BOM | |
How to use this is explained in eeschema.pdf chapter 14. You enter a command line into the | |
netlist exporter using a new (custom) tab in the netlist export dialog. | |
The command line is | |
xsltproc -o "%O.csv" "FullPathToFile/bom2grouped_csv_jlcpcb.xsl" "%I" | |
--> | |
<!-- | |
@package | |
Generates a JLCPCB PCBA service compatible BOM | |
Functionality: | |
* Generate a comma separated value BOM list (csv file type). | |
* Components are sorted by ref and grouped by same value+footprint | |
One value per line | |
Fields are | |
Comment,Designator,Footprint,LCSC | |
The command line is | |
xsltproc -o "%O.csv" "full_path/bom2grouped_csv_jlcpcb.xsl" "%I" | |
--> | |
<!DOCTYPE xsl:stylesheet [ | |
<!ENTITY nl "
"> <!--new line CR, LF, or LF, your choice --> | |
]> | |
<xsl:stylesheet xmlns:xsl="http://www.w3.org/1999/XSL/Transform" version="1.0"> | |
<xsl:output method="text"/> | |
<xsl:variable name="digits" select="'1234567890'" /> | |
<!-- for matching grouping of footprint and value combination --> | |
<xsl:key name="partTypeByValueAndFootprint" match="comp" use="concat(footprint, '-', value)" /> | |
<!-- for table head and empty table fields--> | |
<xsl:key name="headentr" match="field" use="@name"/> | |
<!-- main part --> | |
<xsl:template match="/export"> | |
<xsl:text>Comment,Designator,Footprint,LCSC</xsl:text> | |
<!-- all table entries --> | |
<xsl:apply-templates select="components"/> | |
</xsl:template> | |
<xsl:template match="components"> | |
<!-- for Muenchian grouping of footprint and value combination --> | |
<xsl:for-each select="comp[count(. | key('partTypeByValueAndFootprint', concat(footprint, '-', value))[1]) = 1]"> | |
<xsl:sort select="@ref" /> | |
<xsl:text>&nl;</xsl:text> | |
<xsl:text>"</xsl:text><xsl:value-of select="value"/><xsl:text>","</xsl:text> | |
<!-- list of all references --> | |
<xsl:for-each select="key('partTypeByValueAndFootprint', concat(footprint, '-', value))"> | |
<!-- strip non-digits from reference and sort based on remaining number --> | |
<xsl:sort select="translate(@ref, translate(@ref, $digits, ''), '')" data-type="number" /> | |
<xsl:value-of select="@ref"/> | |
<xsl:if test="position() != last()"><xsl:text>,</xsl:text></xsl:if> | |
</xsl:for-each> | |
<xsl:text>","</xsl:text> | |
<xsl:value-of select="footprint"/><xsl:text>","</xsl:text> | |
<xsl:value-of select="fields/field[@name='LCSC']"/><xsl:text>"</xsl:text> | |
</xsl:for-each> | |
</xsl:template> | |
<!-- table entries with dynamic table head --> | |
<xsl:template match="fields"> | |
<!-- remember current fields section --> | |
<xsl:variable name="fieldvar" select="field"/> | |
<!-- for all existing head entries --> | |
<xsl:for-each select="/export/components/comp/fields/field[generate-id(.) = generate-id(key('headentr',@name)[1])]"> | |
<xsl:variable name="allnames" select="@name"/> | |
<xsl:text>,"</xsl:text> | |
<!-- for all field entries in the remembered fields section --> | |
<xsl:for-each select="$fieldvar"> | |
<!-- only if this field entry exists in this fields section --> | |
<xsl:if test="@name=$allnames"> | |
<!-- content of the field --> | |
<xsl:value-of select="."/> | |
</xsl:if> | |
<!-- | |
If it does not exist, use an empty cell in output for this row. | |
Every non-blank entry is assigned to its proper column. | |
--> | |
</xsl:for-each> | |
<xsl:text>"</xsl:text> | |
</xsl:for-each> | |
</xsl:template> | |
</xsl:stylesheet> |
Hi.` The xsltproc appears to have been removed from KiCAD 7. Here is a solution:
Keep the instructions currently, but one slight change. Create a new .py file with the same name and put it in the same folder as bom2grouped_csv_jlcpcb.xsl and create the file.
and set the commandline to: python "\KiCad\6.0\plugins\bom2grouped_csv_jlcpcb.py" "%I" "%O.csv"Hello, thanks for the update, unfortunately it is not working for me. :( I get the following error:
tree = ET.parse(xml_path) ^ IndentationError: expected an indented block
How could I make it work?
If you install this, it should work fine. The full package for JLCPCB is created without any issue and in a subdir called "Production"
Thanks!
Ref.:
[YouTube: How to Place a PCB Assembly Order at JLCPCB]
Note: Generating Pick and Place files (CPL file (.pos), already included in the package "Production"):
The CPL file has to be generated from the PCB editor, click on "File" -> "Fabrication output" -> "Footprint position (.pos) file" and export the file with the following settings. Source.
Note: "2. Notes on DFM - 1.The design of the PCB footprints must comply with "medium density" or "low density" standards listed in IPC-7351B. High density is not supported." (Terms and Conditions of JLCPCB Assembly Service)
Ref.:
Hi Arthur,
with the KICAD 7.0 I got an error, and I am not clear about the root cause here. Can You probably give an Hint?
This is due to the xsltproc executable being omitted from the installation. I had to transplant it from QMK (the executable) and Git (DLL files) on Windows to get it working. (Not sure on Ubuntu which you seem to be using, please consult your system files)
You need both the library and executable on Windows. Copy over all files named xsltproc.exe
and msys-*.dll
from Git and QMK into KiCad/7.0/bin/
folder to get it working. It's quite annoying.
Thanks!