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í
×
    dnes 05:33 | Nová verze

    Open-source citační manažer Zotero (Wikipedie, GitHub) byl vydán v nové major verzi 9. Přehled novinek v příspěvku na blogu.

    Ladislav Hagara | Komentářů: 0
    včera 18:33 | Komunita

    Libre Graphics Meeting 2026, tj. čtyřdenní konference a setkání vývojářů a uživatelů svobodných a otevřených grafických softwarů, proběhne od 22. do 25. dubna v Norimberku. Dění lze sledovat na Mastodonu.

    Ladislav Hagara | Komentářů: 0
    včera 03:11 | Zajímavý software

    Vývojář Alexandre Gomes Gaigalas na GitHubu zveřejnil c89cc.sh, parser a kompilátor jazyka C89 napsaný v pouhém jediném skriptu o přibližně 8000 řádcích čistého bashe (bez dalších externích závislostí), který generuje ELF64 binárky pro x86-64. Jedná se o velmi jednoduchý kompilátor, který nepodporuje direktivy #include a dokonce ani funkci printf (lze použít puts), všechny dostupné deklarace lze nalézt v proměnné _BUILTIN_LIBC na konci skriptu. Skript je volně dostupný pod ISC licencí.

    » FIDESZ🧡! « | Komentářů: 10
    10.4. 23:33 | Nasazení Linuxu

    Francouzská vláda oznámila, že v rámci strategie 'digitální suverenity' zahájí 'přechod od systému Windows k počítačům s operačním systémem Linux' (sa sortie de Windows au profit de postes sous système d'exploitation Linux). DINUM (meziresortní ředitelství pro digitální technologie) požádalo ministerstva, aby do podzimu 2026 vypracovaly konkrétní plány nasazení Linuxu. Francie již dříve migrovala části státní správy na otevřená řešení.

    » FIDESZ🧡! « | Komentářů: 14
    10.4. 05:22 | IT novinky

    Nezisková organizace Electronic Frontier Foundation (EFF) hájící občanské svobody v digitálním světě po téměř 20 letech opouští platformu X (dříve Twitter). Na platformách Bluesky, Mastodon, LinkedIn, Instagram, TikTok, Facebook, Threads a YouTube zůstává.

    Ladislav Hagara | Komentářů: 5
    10.4. 03:33 | Nová verze

    Terminálový textový editor GNU nano byl vydán ve verzi 9.0. Vylepšuje chování horizontálního posouvání pohledu na dlouhé řádky a chování některých klávesových zkratek. Více v seznamu změn.

    |🇵🇸 | Komentářů: 0
    9.4. 19:22 | IT novinky

    Ministerstvo financí ve spolupráci s finanční správou dnes představilo beta verzi aplikace využívající umělou inteligenci pro předvyplnění daňového přiznání. Není třeba přepisovat údaje z různých potvrzení, ani hledat správné řádky, kam údaje napsat. Stačí nahrát dokumenty a využít AI.

    Ladislav Hagara | Komentářů: 8
    9.4. 18:33 | Zajímavý projekt

    Výrobce počítačových periferií Keychron zveřejnil repozitář se schématy šasi klávesnic a myší. Licence je restriktivní, zakazuje většinu komerčních užití a v podstatě jsou tak data vhodná pouze pro výukové účely, hlášení a opravy chyb, případně výrobu vlastního příslušenství.

    |🇵🇸 | Komentářů: 5
    9.4. 18:22 | Nová verze

    Správce balíčků APT, používaný v Debianu a odvozených distribucích, byl vydán ve verzi 3.2 (seznam změn). Mezi novinkami figurují nové příkazy pro práci s historií, včetně vracení transakcí.

    |🇵🇸 | Komentářů: 0
    9.4. 14:33 | IT novinky

    Společnost Anthropic oznámila Projekt Glasswing a s ní související AI model Claude Mythos Preview. Jedná se o iniciativu zaměřenou na kybernetickou bezpečnost, do které se zapojily velké technologické společnosti Amazon Web Services, Anthropic, Apple, Broadcom, Cisco, CrowdStrike, Google, JPMorganChase, Linux Foundation, Microsoft, NVIDIA a Palo Alto Networks. Anthropic věří, že nový AI model Claude Mythos Preview dokáže

    … více »
    Ladislav Hagara | Komentářů: 2
    Které desktopové prostředí na Linuxu používáte?
     (14%)
     (8%)
     (1%)
     (12%)
     (30%)
     (3%)
     (6%)
     (2%)
     (14%)
     (24%)
    Celkem 1273 hlasů
     Komentářů: 30, poslední 3.4. 20:20
    Rozcestník

    Dotaz: Python: jak spravne extrahovat nazvy souboru z adresare?

    29.3.2016 17:27 zdenek2008 | skóre: 26
    Python: jak spravne extrahovat nazvy souboru z adresare?
    Přečteno: 534×
    Prepisuji si z bashe do pythonu skript, pomoci ktereho generuji (krome jineho) lyx dokument. Do toho lyx dokumentu nacitam externi pdf dokumenty a uvadim je v obsahu (TOC). Zatim mam castecne vyreseny proces zapisovani do souboru (promenne v textu jsou jeste podle bashove syntaxe), ale iterovani v adresari s pdf soubory je jeste (bash) v zakomentovanych radkach. Nemeli byste nekdo tip na nejake elegantni reseni, abych treba nevynalezal nejake kostrbatiny? Predem diky za pripadne navrhy.
    file=open('../soubor.lyx','a')
    
    #for nazev_souboru in ../nejake_pdf_documenty/*.[pP][dD][fF]; do
    #nazev_souboru_bez_pripony=${nazev_souboru:25:-4}
    
    text=r"""\begin_layout Standard
    \begin_inset CommandInset label
    LatexCommand label
    name "${nazev_souboru_bez_pripony}"
    
    \end_inset
    
    
    \end_layout
    
    \begin_layout Standard
    \begin_inset External
    	template PDFPages
    	filename ${nazev_souboru:1}
    	extra LaTeX "pages=-, pagecommand={\thispagestyle{fancy}}, addtotoc={1,section,1,${nazev_souboru_bez_pripony},${nazev_souboru_bez_pripony}}"
    	scale 80
    
    \end_inset
    
    
    \end_layout
    
    """
    
    file.write(text)
    logging.debug('text: '+text)
    
    #done
    
    file.close()
    del file
    del text
    

    Řešení dotazu:


    Odpovědi

    Řešení 1× (zdenek2008 (tazatel))
    xxxxxx avatar 29.3.2016 18:31 xxxxxx | skóre: 23
    Rozbalit Rozbalit vše Re: Python: jak spravne extrahovat nazvy souboru z adresare?
    Ten kus LyX kódu bych hodil do jiného souboru, v kódu tohle obvykle není pěkné. Jestli tomu dobře rozumím, máš šablonu pro LyX, do které chceš nasázet hodnoty. To bych použil rovnou modul Jinja2.
    import glob
    import os
    from jinja2 import Environment
    
    # Načtení šablony do prom. tmp
    env = Environment()
    
    with open('cesta/k/templatu.lyx', 'r', encoding='utf8') as fread:
        tmp = env.from_string(fread.read())
    
    # dict s hodnotami
    content = {}
    
    # Pak tady budeš všechno možné, třeba to prolezení PDF souborů
    # Dejme tomu, že magicka_funkce vrací list s názvy PDF
    def magicka_funkce(path):
        files = glob.glob(path + '*.pdf')
    
        out = []
    
        # Ošklivé, ale takhle nějak
        for fl in files:
            out.append({'cesta': fl,
                        'nazev_souboru': os.path.basename(fl),
                        'nazev_souboru_bez_pripony': os.path.splitext(os.path.basename(fl))[0]})
    
        return out
    
    seznam_souboru = magicka_funkce('cesta/')
    content['seznam_souboru'] = seznam_souboru
    
    # Nakonec ten seznam pošleš šabloně
    vygenerovany_dokument_jako_string = tmp.render(content)
    
    with open('vysledny_soubor.lyx', 'r', encoding='utf8') as fwrite:
        fwrite.write(vygenerovany_dokument_jako_string)
    
    No a v té šabloně budeš mít už syntaxi Jinja:
    {% for pdf in seznam_souboru %}
    \begin_layout Standard
    \begin_inset CommandInset label
    LatexCommand label
    name "{{ pdf.nazev_souboru_bez_pripony }}"
    
    \end_inset
    
    
    \end_layout
    
    \begin_layout Standard
    \begin_inset External
    	template PDFPages
    	filename {pdf.nazev_souboru:1}
    	extra LaTeX "pages=-, pagecommand={\thispagestyle{fancy}}, addtotoc={1,section,1,{{ pdf.nazev_souboru_bez_pripony }}},{{ pdf.nazev_souboru_bez_pripony }}}"
    	scale 80
    
    \end_inset
    
    
    \end_layout
    {% endfor %}
    
    Jakmile generuju soubory, tak takhle. Než jsem se dostal k Jinja2, tak jsem to dělal stejně, jako to máš v otázce, tj. postupně zapisovat do souboru po kouskách. Ale tohle je o poznání jednodušší a čistší. Hlavně to podporuje cykly i podmínky (viz první řádek templatu).

    Kromě Jinja2 má python ve standardní knihovně string.Template. Což je něco podobného, ale spíš jen formou search & replace.
    29.3.2016 19:06 zdenek2008 | skóre: 26
    Rozbalit Rozbalit vše Re: Python: jak spravne extrahovat nazvy souboru z adresare?
    Diky. Co se tyce te iterace tak zatim jsem se dostal k tomuhle:
    nejake_pdf_dokumenty=glob.glob('../nejake_pdf_dokumenty/*.[pP][dD][fF]')
    nejake_pdf_dokumenty.sort()
    logging.debug('nejake_pdf_dokumenty: '+str(nejake_pdf_dokumenty))
    
    for nazev_souboru in nejake_pdf_dokumenty:
      logging.debug('nazev_souboru: '+nazev_souboru)
      nazev_souboru_bez_pripony=nazev_souboru[25:-4]
      logging.debug('nazev_souboru_bez_pripony: '+nazev_souboru_bez_pripony)
    Tim bash skriptem jsem doposud vyplnoval pdf formulare a sadu lyx dokumentu ktere jsem jeste pak dodatecne rucne editoval (jejich obsah, ne kod) a nakonec vse zahrnul do jedineho lyx svazku a ten nakonec opet exportoval do pdf fasciklu pro konecne pouziti. Jak ten skript rostl tak vyslo najevo ze bash uz nevyhovuje a je treba prepsat do jineho jazyka, oddelit sablony od kodu (uz ted mi dochazi ke konfliktum syntaxi lyxu a pythonu, jako treba uvozovky) a pokud jde o kod samotny tak ten je potreba take restrukturalizovat, napsat funkce a rozdelit do vhodnych modulu. Navic bude asi potreba skript distribuovat takze je treba doresit i instalatory na jine OS. Diky za tip na reseni, toto vyuziju.
    xxxxxx avatar 29.3.2016 20:42 xxxxxx | skóre: 23
    Rozbalit Rozbalit vše Re: Python: jak spravne extrahovat nazvy souboru z adresare?
    Jinak jak koukám, vyhnul bych se tomuhle: nazev_souboru[25:-4]. Teď to třeba na 3 písmenné přípony funguje, ale projet složku s jpg/jpeg a už to fungovat nebude. Proto existuje funkce splitext. A jestli bude potřeba skript i na Win, tak v modulu os jsou fce na práci s cestami, které chápou / a \, není pak nutné ve skriptu detekovat os a ručně uplácávat cesty.
    29.3.2016 21:10 zdenek2008 | skóre: 26
    Rozbalit Rozbalit vše Re: Python: jak spravne extrahovat nazvy souboru z adresare?
    Diky, to budu muset take predelat. S cestou k souboru potrebuji zachazet spis "systemove" nez jako s textovym retezcem. Nastesti cely skript uz konecne funguje v pythonu takze ted muzu zacit ladit.

    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.