Josef Průša představil novou velkoformátovou uzavřenou CoreXY 3D tiskárnu Prusa CORE One L a nový open source standard chytrých cívek OpenPrintTag i s novou přepracovanou špulkou.
Na GOG.com běží Autumn Sale. Při té příležitosti je zdarma hororová počítačová hra STASIS (ProtonDB: Platinum).
Ubuntu 25.10 má nově balíčky sestavené také pro úroveň mikroarchitektury x86-64-v3 (amd64v3).
Byla vydána verze 1.91.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.
Ministerstvo průmyslu a obchodu vyhlásilo druhou veřejnou soutěž v programu TWIST, který podporuje výzkum, vývoj a využití umělé inteligence v podnikání. Firmy mohou získat až 30 milionů korun na jeden projekt zaměřený na nové produkty či inovaci podnikových procesů. Návrhy projektů lze podávat od 31. října do 17. prosince 2025. Celková alokace výzvy činí 800 milionů korun.
Google v srpnu oznámil, že na „certifikovaných“ zařízeních s Androidem omezí instalaci aplikací (včetně „sideloadingu“) tak, že bude vyžadovat, aby aplikace byly podepsány centrálně registrovanými vývojáři s ověřenou identitou. Iniciativa Keep Android Open se to snaží zvrátit. Podepsat lze otevřený dopis adresovaný Googlu nebo petici na Change.org.
Byla vydána nová verze 18 integrovaného vývojového prostředí (IDE) Qt Creator. S podporou Development Containers. Podrobný přehled novinek v changelogu.
Cursor (Wikipedie) od společnosti Anysphere byl vydán ve verzi 2.0. Jedná se o multiplatformní proprietární editor kódů s podporou AI (vibe coding).
Google Chrome 142 byl prohlášen za stabilní. Nejnovější stabilní verze 142.0.7444.59 přináší řadu novinek z hlediska uživatelů i vývojářů. Podrobný přehled v poznámkách k vydání. Opraveno bylo 20 bezpečnostních chyb. Za nejvážnější z nich bylo vyplaceno 50 000 dolarů. Vylepšeny byly také nástroje pro vývojáře.
Pro moddery Minecraftu: Java edice Minecraftu bude bez obfuskace.
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:
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.
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.
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.
Tiskni
Sdílej: