abclinuxu.cz AbcLinuxu.cz itbiz.cz ITBiz.cz HDmag.cz HDmag.cz abcprace.cz AbcPráce.cz
AbcLinuxu hledá autory!
Inzerujte na AbcPráce.cz od 950 Kč
Rozšířené hledání
×
    včera 17:11 | Zajímavý článek

    Stanislav Fort, vedoucí vědecký pracovník z Vlčkovy 'kyberbezpečnostní' firmy AISLE, zkoumal dopady Anthropic Mythos (nový AI model od Anthropicu zaměřený na hledání chyb, který před nedávnem vyplašil celý svět) a předvedl, že schopnosti umělé inteligence nejsou lineárně závislé na velikosti nebo ceně modelu a dokázal, že i některé otevřené modely zvládly v řadě testů odhalit ve zdrojových kódech stejné chyby jako Mythos (například FreeBSD CVE-2026-4747) a to s výrazně nižšími provozními náklady.

    MakeIranBombedAgain❗ | Komentářů: 6
    včera 12:44 | IT novinky

    Federální návrh zákona H.R.8250 'Parents Decide Act', 13. dubna předložený demokratem Joshem Gottheimerem a podpořený republikánkou Elise Stefanik coby spolupředkladatelkou (cosponsor), by v případě svého schválení nařizoval všem výrobcům operačních systémů při nastavování zařízení ověřovat věk uživatelů a při používání poskytovat tento věkový údaj aplikacím třetích stran. Hlavní rozdíl oproti kalifornskému zákonu AB 1043 a kolorádskému SB26-051 je ten, že federální návrh by platil rovnou pro celé USA.

    MakeIranBombedAgain❗ | Komentářů: 12
    včera 12:33 | Nová verze

    Qwen (čínská firma Alibaba Cloud) představila novou verzi svého modelu, Qwen3.6‑35B‑A3B. Jedná se o multimodální MoE model s 35 miliardami parametrů (3B aktivních), nativní kontextovou délkou až 262 144 tokenů, 'silným multimodálním vnímáním a schopností uvažování' a 'výjimečnou schopností agentického kódování, která se může měřit s mnohem rozsáhlejšími modely'. Model a dokumentace jsou volně dostupné na Hugging Face, případně na čínském Modelscope. Návod na spuštění je už i na Unsloth.

    MakeIranBombedAgain❗ | Komentářů: 1
    včera 11:00 | Nová verze

    Sniffnet, tj. multiplatformní (Windows, macOS a Linux) open source grafická aplikace pro sledování internetového provozu, byl vydán ve verzi 1.5. V přehledu novinek je vypíchnuta identifikace aplikací komunikujících po síti.

    Ladislav Hagara | Komentářů: 4
    včera 02:22 | Nová verze

    V programovacím jazyce Go naprogramovaná webová aplikace pro spolupráci na zdrojových kódech pomocí gitu Forgejo byla vydána ve verzi 15.0 (Mastodon). Forgejo je fork Gitei.

    Ladislav Hagara | Komentářů: 1
    včera 01:11 | Pozvánky

    Současně se SUSECON 2026 proběhne příští čtvrtek v Praze také komunitní Open Developer Summit (ODS) zaměřený na open source a openSUSE. Akce se koná ve čtvrtek 23. 4. (poslední den SUSECONu) v Hilton Prague (místnost Berlin 3) a je zcela zdarma, bez nutnosti registrace na SUSECON. Na programu jsou témata jako automatizace (AutoYaST), DevOps, AI v terminálu, bezpečnost, RISC-V nebo image-based systémy. Všichni jste srdečně zváni.

    lkocman | Komentářů: 1
    16.4. 15:44 | Humor

    Český úřad zeměměřický a katastrální zavedl u anonymního nahlížení do katastru nemovitostí novou CAPTCHA ve formě mapové puzzle: nepřihlášení uživatelé musí nově správně otočit devět dlaždic v 3x3 poli tak, aby dohromady daly souvislý obrázek výseče reálné mapy, přičemž na to mají pouze jeden časově omezený pokus. Test je podle uživatelů i odborníků příliš obtížný a na sociálních sítích pochopitelně schytává zaslouženou kritiku a

    … více »
    MakeIranBombedAgain❗ | Komentářů: 34
    16.4. 15:33 | Nová verze

    Byla vydána verze 1.95.0 programovacího jazyka Rust (Wikipedie). Podrobnosti v poznámkách k vydání. Vyzkoušet Rust lze například na stránce Rust by Example.

    Ladislav Hagara | Komentářů: 0
    16.4. 15:22 | Zajímavý software

    Mozilla prostřednictvím své dceřiné společnosti MZLA Technologies Corporation představila open-source AI klienta Thunderbolt. Primárně je určený pro firemní nasazení.

    Ladislav Hagara | Komentářů: 0
    16.4. 14:00 | IT novinky

    Firma Cal.com oznámila, že přesouvá svůj produkční kód z otevřeného do uzavřeného repozitáře z důvodu bezpečnostního rizika umělé inteligence, která prý dokáže vyhledávat a zneužívat zranitelnosti rychleji, než by je jejich vývojářský tým stíhal opravovat. Zároveň zveřejnila samostatnou, open-source verzi Cal.diy pod licencí MIT, ovšem bez řady původních funkcí. O tom, zda je toto opatření rozumné, existují pochyby. … více »

    MakeIranBombedAgain❗ | Komentářů: 6
    Které desktopové prostředí na Linuxu používáte?
     (14%)
     (8%)
     (1%)
     (12%)
     (30%)
     (3%)
     (6%)
     (2%)
     (15%)
     (25%)
    Celkem 1354 hlasů
     Komentářů: 30, poslední 3.4. 20:20
    Rozcestník

    Příprava štítků s čárovými kódy (python-reportlab)

    19.5.2014 22:27 | Přečteno: 1606× | poslední úprava: 19.5.2014 22:35

    Po mém předchozím zápisku o webové aplikaci www.123stitky.cz pro tvorbu adresních štítků dnes rozeberu, jak jsou tyto štítky generovány v Pythonu s použitím knihovny Reportlab. Dostane se nejen na textové štítky, ale i na to, jak do nich vložit QR kód a EAN čárový kód.

    Možností, jak programově generovat PDF je celá řada. Ale protože pro mě je Python jazyk, ve kterém píši již 13 let a o kterém jsem před těmi 13 roky psal, je volba jasná.

    Reportlab

    Reportlab je pythonovský balíček modulů pro programové generování PDF. Kromě odkazované open-source verze (dokumentace, jak jinak, než v PDF) je k dispozici i placená verze, kde se připlácí především za šablonovací systém a podporu. V dnešní ukázce žádné pokročilé vlastnosti nevyužijeme, proto na Debianu nainstalujeme balíček python-reportlab a kód můžeme rovnou otestovat.

    V této jednoduché ukázce si řekneme, jak za použití vlastního TTF fontu vykreslit text odpovídající jednotlivým řádkům štítku, štítku nastavit vlastní velikost a pak do definovaných míst vykreslíme QR kód a EAN čárový kód. Protože vykreslení čárových kódů o přesně daném rozměru není z mého pohledu tak průhledné, jak by mohlo být, ukáži jednoduchou funkci, jak čárový kód ztransformovat tak, aby se vykreslil přesně tam, kam potřebujeme. V následující ukázce následují jednotlivé fragmenty kódu, přičemž odpovídající importy (z) modulů jsou vždy na začátku fragmentu. Při psaní produkčního kódu by bylo dobré dát je na začátek zdrojového souboru.

    Začínáme

    Nejprve si vytvoříme objekt out, instanci třídy Canvas, do kterého budeme kreslit obsah štítku. První parametr je jméno souboru, do kterého bude výstup uložen:
    from reportlab.pdfgen import canvas
    from reportlab.lib.units import mm, inch
    
    PAGE_WIDTH = 100*mm
    PAGE_HEIGHT = 50*mm
    
    out = canvas.Canvas('out.pdf', pagesize=(PAGE_WIDTH, PAGE_HEIGHT))
    
    Reportlab používá vtipný způsob pro práci s rozměry, z modulu units si můžete naimportovat milimetry (mm) nebo palce (inch) a rozměry zadávat jako jejich násobky (viz PAGE_WIDTH, PAGE_HEIGHT). Rozměry Canvasu jsou předány jako tuple o dvou hodnotách, pokud chcete použít standardní rozměr stránky, použijte:
    from reportlab.lib.pagesizes import A4
    out = canvas.Canvas('out.pdf', pagesize=A4)
    

    Vlastní font

    Chceme kreslit vlastním TTF fontem. Pro ukázku použijeme DejaVu font z Debianího balíku ttf-dejavu-core. Font vytvoříme a zaregistrujeme pod vlastním názvem pomocí kódu:

    from reportlab.pdfbase import pdfmetrics 
    from reportlab.pdfbase.ttfonts import TTFont 
    
    FONT_NAME = 'DejaVuSans'
    font = TTFont(FONT_NAME, '/usr/share/fonts/truetype/ttf-dejavu/DejaVuSans.ttf')
    pdfmetrics.registerFont(font)
    FONT_SIZE = 10
    

    Jdeme kreslit

    Před kreslením nejprve nastavím náš načtený font a pak vykreslíme čtyři řádky. Reportlab měří vzdálenosti od levého dolního rohu, stejně tak text renderovaný pomocí drawString() má svůj levý dolní roh na pozici předané jako parametr:

    out.setFont(FONT_NAME, FONT_SIZE)
    
    out.drawString(10*mm, 10*mm, u"Řádek 4")
    out.drawString(10*mm, 20*mm, u"Řádek 3")
    out.drawString(10*mm, 30*mm, u"Řádek 2")
    out.drawString(10*mm, 40*mm, u"Řádek 1")
    

    Příprava na čárové kódy

    Základní kostru kódu, jak v Reportlabu tisknout QR kódy a EAN čárové kódy jsem vzdal ze stackoverflow, kde ale parametr transform je určen jasně nejasně a spíše tak, aby to fungovalo. Tento parametr určuje transformační matici a nechá se získat pomocí funkcí translate a scale z modulu reportlab.graphics.shapes. Já jsem se však inspiroval pohledem na tento zdrojový kód, kde je vše nutné. Definujme tedy funkci, která dokáže vykreslit kód do Canvasu. Její parametry: Po vytvoření instance třídy Drawing do ní přidáme čárový kód a vykreslíme do PDF canvasu. Nakonec, spíše pro ilustraci nakreslíme rámeček okolo čárového kódu, abychom věděli odkud kam sahá.
    from reportlab.graphics.shapes import Drawing
    from reportlab.graphics import renderPDF
    
    
    def draw_barcode(canvas, x, y, width, height, w_type, text):
        code = w_type(value=text)
        x1, y1, x2, y2 = code.getBounds()
        w = float(x2 - x1)
        h = float(y2 - y1)
    
        sx = width/w
        sy = height/h
    
        w *= sx
        h *= sy
    
        drawing = Drawing(width=w,height=h,transform=[sx,0,0,sy,-sx*x1,-sy*y1])
        drawing.add(code)
        renderPDF.draw(drawing, canvas, x, y)
    
        canvas.rect(x, y, width, height)
    

    Čárové kódy

    Nyní tuto funkci použijeme pro vykreslení QR kódu a EAN čárového kódu. Při tom použijeme třídy QrCodeWidget a Ean13BarcodeWidget, ale můžeme generovat celou řadu jiných kódů (viz dokumentace reportlab.graphics).

    Nejprve tedy importy:

    from reportlab.graphics.barcode.qr import QrCodeWidget 
    from reportlab.graphics.barcode.eanbc import Ean13BarcodeWidget
    
    Vykreslení QR kódu do pravého horního rohu štítku:
    W = 24*mm
    H = 24*mm
    draw_barcode(out, PAGE_WIDTH-W, PAGE_HEIGHT-H, W, H,
        QrCodeWidget, 'https://www.123stitky.cz')
    
    A čárového EAN13 kódu do pravého dolního rohu štítku. Pro informace o rozměrech EAN kódu jsem použil tuto stránku:
    W = 37.29*mm
    H = 25.93*mm
    draw_barcode(out, PAGE_WIDTH-W, 0, W, H,
        Ean13BarcodeWidget, '79357367900')
    

    Ukládáme

    Nyní již štítek můžeme uložit do PDF jednoduchým voláním metody save(). Po tomto volání již Canvas nemůžeme používat, zato se může podívat do souboru out.pdf (viz volání konstruktoru Canvas):
    out.save()
    

    Poznámky

    Pokud budete chtít v PDF více stránek, pak zavolejte out.showPage() pro založení nové stránky.

    Prostřednictvím modulu reportlab.graphics lze renderovat nejen PDF (renderPDF), ale i bitmapové formáty (renderPM) nebo SVG (renderSVG).

    Pro generování náhledu štítků na první stránce www.123stitky.cz používám PNG, které konvertuji z PDF pomocí balíčku wand což je ctypes binding nad ImageMagickem a jeho použití vypadá následovně (v preview je string obsahující BLOB s PNG):

    from wand.image import Image
    
    with Image(filename="out.pdf[0]", resolution=150) as img:
        preview = img.make_blob(format='png')
    

    Závěr

    Reportlab je velice silný nástroj a v tomto zápisku je popsána jen velice omezená podmnožina funkcí, kterou používám pro on-line generování dopisních a jiných štítků ve webové aplikaci www.123stitky.cz. Reportlab navíc umí sázet text do odstavců, měnit styl písma, zarovnávat text, kreslit tvary různými barvami, vytvářet tabulky a spoustu dalšího, přesto věřím, že některým z vás tento kód může pomoci a usnadnit tvorbu PDF dokumentů s QR, EAN nebo jinými čárovými či 2D kódy.        

    Hodnocení: 88 %

            špatnédobré        

    Tiskni Sdílej: Linkuj Jaggni to Vybrali.sme.sk Google Del.icio.us Facebook

    Komentáře

    Vložit další komentář

    19.5.2014 22:29 Jan Švec | skóre: 2 | blog: honzas | Plzeň
    Rozbalit Rozbalit vše Re: Příprava štítků (python-reportlab)
    Příloha:
    Přikládám IPython notebook (zdrojový kód) pro experimentování.
    19.5.2014 22:59 Stevko | skóre: 3 | Praha
    Rozbalit Rozbalit vše Re: Příprava štítků s čárovými kódy (python-reportlab)
    V Brmlabe na čiarové kódy používame pythoní skript z https://github.com/brmlab/misc (barcodes.py), ktorý vyrobí pomocou zintu svg s kódmi a naskladá ich na vhodné miesta do väčšieho svg (tak, aby to sedelo na samolepky). Ale samozrejme, dá sa využiť gnu barcode (sh skriptík tiež tam).
    Príspevok nemá byť ukončený spojením „môj názor“.
    20.5.2014 14:49 Marv-CZ | skóre: 21
    Rozbalit Rozbalit vše Re: Příprava štítků s čárovými kódy (python-reportlab)
    Ony na to existují i aplikace, např. gLabels. Ale chápu, že používat GUI je trapné. :-)
    20.5.2014 09:18 Zbyšek
    Rozbalit Rozbalit vše Re: Příprava štítků s čárovými kódy (python-reportlab)
    Trapná reklama.
    20.5.2014 13:03 smazáno | skóre: 18 | blog: smazáno
    Rozbalit Rozbalit vše Re: Příprava štítků s čárovými kódy (python-reportlab)
    Na open-source reportlab.
    Salamek avatar 21.5.2014 10:27 Salamek | skóre: 22 | blog: salamovo
    Rozbalit Rozbalit vše Re: Příprava štítků s čárovými kódy (python-reportlab)
    https://www.123stitky.cz/jaknato Uplne dole se nenahravaji dva obrazky...
    Skutečně nemám v plánu zničit Microsoft. Bude to jen zcela neúmyslný vedlejší efekt.

    Založit nové vláknoNahoru

    ISSN 1214-1267   www.czech-server.cz
    © 1999-2015 Nitemedia s. r. o. Všechna práva vyhrazena.