← Back to team overview

kicad-developers team mailing list archive

Re: Are the python BOMmers case sensitive?

 

On 09/19/2013 09:39 AM, Lorenzo Marcantonio wrote:
> On Thu, Sep 19, 2013 at 04:28:17PM +0200, Lorenzo Marcantonio wrote:
>> so something like c.getRef().encode('utf8') and so one probably would do
>> the trick. BTW I'm perfectly fine with the xslt generators, so I'll try
>> this and only if it work at the first try I'll do a patch for it.
> 
> This solve the unicode issue (absolutely no elegance whatsoever, but I hope
> there is something like mapcar in python). Also it seems to exist a unicodecvs
> module which does the trick (but I don't have it)
> 
> === modified file 'scripts/bom-in-python/bom_csv_by_ref_v2.py'
> --- scripts/bom-in-python/bom_csv_by_ref_v2.py  2013-09-01 17:49:01 +0000
> +++ scripts/bom-in-python/bom_csv_by_ref_v2.py  2013-09-19 14:33:32 +0000
> @@ -27,8 +27,10 @@
>  out = csv.writer(f, lineterminator='\n', delimiter=',', quotechar="\"", quoting=csv.QUOTE_ALL)
>  
>  # Output a field delimited header line
> -out.writerow(['Source:', net.getSource()])
> -out.writerow(['Date:', net.getDate()])
> +out.writerow(['Source:', net.getSource().encode('utf8')])
> +out.writerow(['Date:', net.getDate().encode('utf8')])
> +
> +# Hope that the kicad version string will never need utf8 encoding...
>  out.writerow(['Tool:', net.getTool()])
>  out.writerow(['Component Count:', len(net.components)])
>  out.writerow(['Ref', 'Value', 'Footprint', 'Datasheet', 'Manufacturer', 'Vendor'])
> @@ -36,7 +38,13 @@
>  components = net.getInterestingComponents()
>  
>  # Output all of the component information (One component per row)
> +# Probably you could apply the encode('utf8') as a map operation but
> +# I have no idea of the python syntax
>  for c in components:
> -    out.writerow([c.getRef(), c.getValue(), c.getFootprint(), c.getDatasheet(),
> -        c.getField("Manufacturer"), c.getField("Vendor")])
> +    out.writerow([c.getRef().encode('utf8'), 
> +        c.getValue().encode('utf8'), 
> +        c.getFootprint().encode('utf8'), 
> +        c.getDatasheet().encode('utf8'),
> +        c.getField("Manufacturer").encode('utf8'), 
> +        c.getField("Vendor").encode('utf8')])


Lorenzo, thanks for the help.  I committed a more localized approach, supplying a single
function to handle the column writing, but it was based on your idea and research.  Thanks.

BTW, my favorite bom generator is the bom_csv_grouped_by_value.py.

I guess each will have his/her own favourite, and that was the idea of getting BOM
generation out into the scripting world.

Dick




References