NiceGUI umožňuje používat webový prohlížeč jako frontend pro kód v Pythonu. Zdrojové kódy jsou k dispozici na GitHubu pod licencí MIT.
Open source platforma Home Assistant (Demo, GitHub, Wikipedie) pro monitorování a řízení inteligentní domácnosti byla vydána ve verzi 2024.6. Z novinek lze vypíchnout lepší integraci LLM (OpenAI, Google AI, Ollama) nebo podporu Matter 1.3.
IKEA ve Spojeném království hledá zaměstnance do své nové pobočky. Do pobočky v počítačové hře Roblox. Nástupní mzda je 13,15 liber na hodinu.
Alyssa Rosenzweig se v příspěvku na svém blogu Vulkan 1.3 na M1 za 1 měsíc rozepsala o novém Vulkan 1.3 ovladači Honeykrisp pro Apple M1 splňujícím specifikaci Khronosu. Vychází z ovladače NVK pro GPU od Nvidie. V plánu je dále rozchodit DXVK a vkd3d-proton a tím pádem Direct3D, aby na Apple M1 s Asahi Linuxem běžely hry pro Microsoft Windows.
Byla vydána (𝕏) květnová aktualizace aneb nová verze 1.90 editoru zdrojových kódů Visual Studio Code (Wikipedie). Přehled novinek i s náhledy a animovanými gify v poznámkách k vydání. Ve verzi 1.90 vyjde také VSCodium, tj. komunitní sestavení Visual Studia Code bez telemetrie a licenčních podmínek Microsoftu.
Byla vydána (Mastodon, 𝕏) nová verze 2024.2 linuxové distribuce navržené pro digitální forenzní analýzu a penetrační testování Kali Linux (Wikipedie). Přehled novinek se seznamem nových nástrojů v oficiálním oznámení.
Počítačová hra Tetris slaví 40 let. Alexej Pažitnov dokončil první hratelnou verzi 6. června 1984. Mezitím vznikla celá řada variant. Například Peklo nebo Nebe. Loni měl premiéru film Tetris.
MicroPython (Wikipedie), tj. implementace Pythonu 3 optimalizovaná pro jednočipové počítače, byl vydán ve verzi 1.23.0. V přehledu novinek je vypíchnuta podpora dynamických USB zařízení nebo nové moduly openamp, tls a vfs.
Canonical vydal Ubuntu Core 24. Představení na YouTube. Nová verze Ubuntu Core vychází z Ubuntu 24.04 LTS a podporována bude 12 let. Ubuntu Core je určeno pro IoT (internet věcí) a vestavěné systémy.
Databáze DuckDB (Wikipedie) dospěla po 6 letech do verze 1.0.0.
from pathlib import Path cesta_k_souborum = Path('/home/user/litigation/evidentiary_documents')To normalne funguje. Ale kdyz "from pathlib import Path" dam na zacatek skriptu, kde ma spravne byt, tak konzole zahlasi toto:
cesta_k_souborum = Path('/home/user/litigation/evidentiary_documents') UnboundLocalError: local variable 'Path' referenced before assignmentTen skript importuji do jineho skriptu jako modul a zkusil jsem "from pathlib import Path" dat toho importujiciho skriptu, ale to nepomohlo. Takze zatim jsem ten import dal dovnitr funkce tam kde funguje, ale spravne to asi neni. Nevedeli byste nekdo co s tim je? Kdyztak predem diky za pripadne tipy.
Řešení dotazu:
global cesta_k_souborum = Path('/home/user/litigation/evidentiary_documents')Pomohlo?
print(dir())
$ python3 -m create_bundle print dir(): ['Path', 'Template', '__builtins__', '__cached__', '__doc__', '__file__', '__loader__', '__name__', '__package__', '__spec__', 'pyperclip']Struktura kodu je velice jednoducha. S importem Path uvnitr funkce to funguje, ale jakmile ten import zakomentuji, hlasi to tu chybu.
#!/usr/bin/python3 # -*- coding: utf-8 -*- #import glob import pyperclip from pathlib import Path from string import Template print('print dir():', dir()) def create_bundle(**kwargs): #.# |#powderblue|bundle| #.# #khaki:create_bundle(**kwargs) #.# - #.# :sestavime zdrojak_tex - #.# do latexove sablony doplnime udaje #.# headings, #.# parties, #.# particulars_of_claim, #.# witness_statement, #.# filename_dated = #.# dated_yyyy - dated_mm - dated_dd; zdrojak_tex = Template(r'''\documentclass[12pt,english]{article} \usepackage[T1]{fontenc} %\usepackage[latin9]{inputenc} \usepackage[utf8]{inputenc} %\usepackage{charter} \usepackage{helvet} \renewcommand{\familydefault}{\sfdefault} \usepackage[a4paper]{geometry} \geometry{verbose,tmargin=3.5cm,bmargin=3.5cm,lmargin=3.3cm,rmargin=3.5cm,headheight=0.5cm,headsep=0.5cm,footskip=2cm} \usepackage{fancyhdr} \pagestyle{fancy} \lhead{} \rhead{} \cfoot{} \rfoot{\bf{\Large{Page \thepage}}} \renewcommand{\headrulewidth}{0pt} \setcounter{secnumdepth}{-1} \setcounter{tocdepth}{1} \usepackage{graphicx} \usepackage{grffile} \usepackage{pdfpages} \usepackage{setspace} \PassOptionsToPackage{normalem}{ulem} \usepackage{ulem} \doublespacing \makeatletter %%%%%%%%%%%%%%%%%%%%%%%%%%%%%% LyX specific LaTeX commands. %% Because html converters don't know tabularnewline \providecommand{\tabularnewline}{\\} %% A simple dot to overcome graphicx limitations \newcommand{\lyxdot}{.} \makeatother \usepackage{babel} \begin{document} $headings $parties \begin{center} \textbf{}% \begin{tabular}{c} \hline INDEX TO APPLICATION BUNDLE\tabularnewline \hline \end{tabular} \par\end{center} \renewcommand\contentsname{} \tableofcontents{} \includepdf[pages=-, pagecommand={\thispagestyle{fancy}}, addtotoc={1,section,1,. . . . . . . . . . . . DIVIDER 1 - STATEMENTS OF CASE,DIVIDER_1_-_STATEMENTS_OF_CASE},scale=0.8]{"/home/user/litigation/DIVIDER 1 - STATEMENTS OF CASE"} \label{$filename_dated - Claim Form N1} ... ZDE JESTE POKRACUJE DLOUHA ALE IRELEVANTNI SABLONA LATEXU ... zdrojak_tex = zdrojak_tex.substitute(headings = kwargs['headings'], parties = kwargs['parties'], particulars_of_claim = kwargs['particulars_of_claim'], witness_statement = kwargs['witness_statement'], filename_dated = f"{kwargs['dated_yyyy']}-{kwargs['dated_mm']}-{kwargs['dated_dd']}") #.# :v adresari evidentiary_documents najdeme vsechna pdfka #.# a setridime podle nazvu; evidentiary_documents = [] from pathlib import Path cesta_k_souborum = Path('/home/user/litigation/evidentiary_documents') for i in cesta_k_souborum.glob('*.[pP][dD][fF]'): #print(i) evidentiary_documents.append(i) evidentiary_documents.sort() kod pokracuje...
>>> def f(): ... print(a) ... a = 2 ... >>> f() Traceback (most recent call last): File "<stdin>", line 1, in <module> File "<stdin>", line 2, in f UnboundLocalError: local variable 'a' referenced before assignmentProtože je tam
a = 2
, je a
místní proměnná f
, ale print(a)
k ní přistupuje dříve, než je této místní proměnné přiřazena hodnota.
Je to také v ČKD Pythonu detaily jsou v dokumentaci.
pathlib
) proměnné (zde Path
).
No a ta logika je celkem prostá, jedno standardní a popsané chování a toho se držíme, žádné speciální zacházení a výjimky pro různé (mírně) odlišné situace a varianty zhruba téhož.
Tiskni Sdílej: