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 21:22 | Nová verze

    Bylo vydáno Eclipse IDE 2025-09 aneb Eclipse 4.37. Představení novinek tohoto integrovaného vývojového prostředí také na YouTube.

    Ladislav Hagara | Komentářů: 0
    včera 18:22 | IT novinky

    T-Mobile od 15. září zpřístupňuje RCS (Rich Communication Services) zprávy i pro iPhone.

    Ladislav Hagara | Komentářů: 2
    včera 13:22 | IT novinky

    Společnost ARM představila platformu Arm Lumex s Arm C1 CPU Cluster a Arm Mali G1-Ultra GPU pro vlajkové chytré telefony a počítače nové generace.

    Ladislav Hagara | Komentářů: 0
    včera 05:44 | Nová verze

    Unicode Consortium, nezisková organizace koordinující rozvoj standardu Unicode, oznámila vydání Unicode 17.0. Přidáno bylo 4 803 nových znaků. Celkově jich je 159 801. Přibylo 7 nových Emoji.

    Ladislav Hagara | Komentářů: 0
    9.9. 21:00 | IT novinky Ladislav Hagara | Komentářů: 14
    9.9. 18:33 | Nová verze

    Realtimová strategie Warzone 2100 (Wikipedie) byla vydána ve verzi 4.6.0. Podrobný přehled novinek, změn a oprav v ChangeLogu na GitHubu. Nejnovější verzi Warzone 2100 lze již instalovat také ze Snapcraftu a Flathubu.

    Ladislav Hagara | Komentářů: 1
    9.9. 12:22 | IT novinky

    Polské vývojářské studio CD Projekt Red publikovalo na Printables.com 3D modely z počítačové hry Cyberpunk 2077.

    Ladislav Hagara | Komentářů: 1
    9.9. 11:44 | Pozvánky

    Organizátoři konference LinuxDays 2025 vydali program a zároveň otevřeli registrace. Akce se uskuteční 4. a 5. října na FIT ČVUT v pražských Dejvicích, kde vás čekají přednášky, workshopy, stánky a spousta šikovných lidí. Vstup na akci je zdarma.

    Petr Krčmář | Komentářů: 7
    8.9. 22:00 | IT novinky

    Uživatelé komunikátoru Signal si mohou svá data přímo v Signalu bezpečně zálohovat a v případě rozbití nebo ztráty telefonu následně na novém telefonu obnovit. Zálohování posledních 45 dnů je zdarma. Nad 45 dnů je zpoplatněno částkou 1,99 dolaru měsíčně.

    Ladislav Hagara | Komentářů: 0
    8.9. 18:44 | Zajímavý článek

    Server Groklaw, zaměřený na kauzy jako právní spory SCO týkající se Linuxu, skončil před 12 lety, resp. doména stále existuje, ale web obsahuje spam propagující hazardní hry. LWN.net proto v úvodníku připomíná důležitost zachovávání komunitních zdrojů a upozorňuje, že Internet Archive je také jen jeden.

    🇵🇸 | Komentářů: 32
    Pro otevření více webových stránek ve webovém prohlížečí používám
     (83%)
     (7%)
     (2%)
     (2%)
     (4%)
     (2%)
    Celkem 163 hlasů
     Komentářů: 12, poslední včera 13:00
    Rozcestník

    Dotaz: logging v Pythonu

    16.10.2015 11:36 Pat1 | skóre: 15
    logging v Pythonu
    Přečteno: 343×
    Pouzivam v pythonu modul logging a rad bych dosahl hierarchickeho oznacovani logu z jednotlivych modulu.

    Nyni pouzivam knihovnu nasledujicim zpusobem:

    #app1.py

    import logging

    logger = logging.getLogger('app1')

    #mod1.py

    import logging

    logger = logging.getLogger('app1.mod1')

    S vystupem jsem nyni spokojen, rad bych ale pridal druhou aplikaci vyuzivajici stejny modul a tady narazim na problem. Rad bych aby se prvni cast parametru v getLogger menila podle toho z jake aplikace je modul importovan. Nejak se mi nedari zjistit jak na to. Existuje nejaky cisty zpusob jak dosahnout pozadovaneho vysledku?

    Řešení dotazu:


    Odpovědi

    Řešení 1× (Pat1 (tazatel))
    16.10.2015 13:25 Sajfi | skóre: 8
    Rozbalit Rozbalit vše Re: logging v Pythonu
    Cesty jsou různé, pokud chceš co nejméně měnit stávající kód, řešil bych to přes Formatter:
    
    import logging
    
    # ----- inicializace logovani pri startu app -----
    
    formatter = logging.Formatter("%(asctime)s %(levelname)s app1.%(name)s %(message)s")
    
    console_handler = logging.StreamHandler()
    console_handler.level = logging.INFO
    console_handler.formatter = formatter
    
    root = logging.getLogger()
    root.addHandler(console_handler)
    root.level = logging.INFO
    
    # ----- kdekoliv v app -----
    
    logging.info("foo")
    
    logger1 = logging.getLogger("logger1")
    logger1.info("baz")
    
    logger2 = logging.getLogger("logger2")
    logger2.info("bar")
    
    A na inicializaci logování je logging.config.dictConfig nebo logging.config.fileConfig, takže by odpadnul kód v ukázce a stačilo by dvě řádky:
    
    import logging
    
    logging.lileConfig('/soubor/s/konfiguraci.ini')
    
    Na stávající kód nebude pořeba sáhnout a vše bude jen konfigurace aplikace a její inicializace při startu.
    17.10.2015 10:44 Pat1 | skóre: 15
    Rozbalit Rozbalit vše Re: logging v Pythonu
    Napsat jmeno aplikace rovnou do formatteru, jak jednoduche (: Je to jina cesta nez nad kterou jsem premyslel, ale je to presne ono. Diky

    Založit nové vláknoNahoru

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

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