V Lucemburku byly oznámeny výsledky posledního kola výzev na evropské továrny pro umělou inteligenci neboli AI Factories. Mezi úspěšné žadatele patří i Česká republika, potažmo konsorcium šesti partnerů vedené VŠB – Technickou univerzitou Ostrava. V rámci Czech AI Factory (CZAI), jak se česká AI továrna jmenuje, bude pořízen velmi výkonný superpočítač pro AI výpočty a vznikne balíček služeb poskytovaný odborníky konsorcia. Obojí bude sloužit malým a středním podnikům, průmyslu i institucím veřejného a výzkumného sektoru.
Byla vydána (𝕏) zářijová aktualizace aneb nová verze 1.105 editoru zdrojových kódů Visual Studio Code (Wikipedie). Přehled novinek i s náhledy a videi v poznámkách k vydání. Ve verzi 1.105 vyjde také VSCodium, tj. komunitní sestavení Visual Studia Code bez telemetrie a licenčních podmínek Microsoftu.
Ve Firefoxu bude lepší správa profilů (oddělené nastavení domovské stránky, nastavení lišt, instalace rozšíření, uložení hesla, přidání záložky atd.). Nový grafický správce profilů bude postupně zaváděn od 14.října.
Canonical vydal (email) Ubuntu 25.10 Questing Quokka. Přehled novinek v poznámkách k vydání. Jedná se o průběžné vydání s podporou 9 měsíců, tj. do července 2026.
ClamAV (Wikipedie), tj. multiplatformní antivirový engine s otevřeným zdrojovým kódem pro detekci trojských koní, virů, malwaru a dalších škodlivých hrozeb, byl vydán ve verzi 1.5.0.
Byla vydána nová verze 1.12.0 dynamického programovacího jazyka Julia (Wikipedie) určeného zejména pro vědecké výpočty. Přehled novinek v příspěvku na blogu a v poznámkách k vydání. Aktualizována byla také dokumentace.
V Redisu byla nalezena a v upstreamu již opravena kritická zranitelnost CVE-2025-49844 s CVSS 10.0 (RCE, vzdálené spouštění kódu).
Ministr a vicepremiér pro digitalizaci Marian Jurečka dnes oznámil, že přijme rezignaci ředitele Digitální a informační agentury Martina Mesršmída, a to k 23. říjnu 2025. Mesršmíd nabídl svou funkci během minulého víkendu, kdy se DIA potýkala s problémy eDokladů, které některým občanům znepříjemnily využití možnosti prokázat se digitální občankou u volebních komisí při volbách do Poslanecké sněmovny.
Společnost Meta představila OpenZL. Jedná se o open source framework pro kompresi dat s ohledem na jejich formát. Zdrojové kódy jsou k dispozici na GitHubu.
Google postupně zpřístupňuje českým uživatelům Režim AI (AI Mode), tj. nový režim vyhledávání založený na umělé inteligenci. Režim AI nabízí pokročilé uvažování, multimodalitu a možnost prozkoumat jakékoliv téma do hloubky pomocí dodatečných dotazů a užitečných odkazů na weby.
Řešení dotazu:
while read line; do echo $line; done < soubor.txt
IFSThe Internal Field Separator that is used for word splitting after expansion and to split lines into words with the
read
builtin command. The default value is ''<space><tab><newline>''.
Zdravim,
ak sa snazis robit nieco v bash-i, tak sa to treba snazit robit v bash-i a nie volat daky iny program zbytocne. Najma ak je to nieco jednoduche a bash samotny ma toto implementovane. Samozrejme, su pripady, kedy je lepsie zavolat externy program, ktory to spravi rychlejsie, ale nie v tomto pripade. ;)
#! /bin/bash while read LINE do # ${PREMENNA%%;*} - vymaze najdlhsi nalez od konca hodnoty premennej po znak ; (bodkociarka) echo "${LINE%%;*}" done< ./seznam.txt
#!/bin/bash seznam=seznam.txt # zde se předpokládá, že seznam.txt leží ve stejném adresáři jako samotný skript - jinak se musí pochopitelně uvést cesta k souboru se seznamem cat $seznam | while read x ; do cesta="$( echo $x | cut -d ";" -f 1 )" soubor="$( echo $x | cut -d ";" -f 3 )" heslo="$( echo $x | cut -d ";" -f 2 )" mkdir "$cesta" cp "$soubor.zip" "$cesta" cd "$cesta" unzip -P "$heslo" "$soubor.zip" rm -rvf "$soubor.zip" cd .. done
Zdravim,
vidiet, ze ste sa snazili a zrejme ste s nim aj spokojny. V podstate robi, co ma, az kym nenastanu problemy.
1. Ziadne overovanie, ci dany subor ci adresar existuju. Vid prikaz test a if v bash-i.
2. cat $seznam moze narobit paseku, ak sa v ceste alebo adresari nachadza medzera. Vid uvodzovanie v bash-i.
3. Ziadne overovanie, ci seznam.txt je to, co potrebujete a taktiez moznost zadania ineho umiestnenia je pomocou upravy skriptu. Vid pozicne parametry v bash-i.
Mozno je tam toho aj viac, ale ja musim spat k svojej praci. A neberte to nijak zle, ja napr. vzdy ocenujem, ked ma niekto napomenie. ;)
Tu je aj moja verzia. Mozte to upravit alebo ignorovat. Akokolvek, nebolo to ani raz otestovane, takze mozu tam byt chyby a preto to otestujte prv na necisto, teda ak to vobec pouzijete.
#!/bin/bash declare -i E_SEZNAM declare DEF_SEZNAM SEZNAM E_SEZNAM=1 SEZNAM='seznam.txt' # vychodzi zoznam sa nachadza v aktualnom adresari, podla mojho nazoru lepsie riesenie DEF_SEZNAM="${PWD}"/"${SEZNAM}" # tvoje riesenie, ked sa vychodzi zoznam nachadza v adresari so skriptom # odkomentuje, ak to chces a zakomentuje predchadzajucu definiciu DEF_SEZNAM # ${PREMENNA%/*} odstrani najkratsi nalez od konca hodnoty premennej po / # ${0} je cesta ku skriptu #DEF_SEZNAM="${0%/*}"/"${SEZNAM}" # Ak nebol zadany pomocou tento_script cesta_k_seznamu, tak sa pouzije seznam.txt z # aktualneho adresara, ak existuje. SEZNAM="${1:-${DEF_SEZNAM}}" SEZNAM="$(readlink -f "${SEZNAM}")" if [[ $? -eq 0 && -r "${SEZNAM}" ]] then echo "Nacitavam seznam z: ${SEZNAM}" # odkomentuj, ak chces mat aj moznost prerusenia skriptu v pripade, # ze seznam.txt nie je to, co si si myslel alebo co si chcel spracovat. # echo -e "Citam prvych 5 riadkov v ${SEZNAM}\ # ---------------------------------------" # head -n 5 "${SEZNAM}" # echo -e "---------------------------------------\n" # read -p 'Pokracovat ? ' && exit ${E_SEZNAM} else echo "${SEZNAM} neexistuje. Koncim." exit ${E_SEZNAM} fi while read LINE do # vymaze najdlhsi nalez od konca po znak ; # pracujeme s absolutnymi cestami, mozno (teda som si isty ;) ) by tu bolo vhodne dat overovanie # ci ta cesta aj existuje, aby sa predislo nahodnemu prepisaniu niektoreho doleziteho # suboru. To je na tebe. ;) Celkom jednoducha podmienka pomocou if to vyriesi. A to rovnako # pri CESTA i pri SOUBOR CESTA="$(readlink -f "${LINE%%;*}")" # vymaze najdlhsi nalez od zaciatku po znak ; SOUBOR="$(readlink -f "${LINE##*;}")" # zobrazi hodnotu medzi dvoma znakmi ; HESLO="$(expr match "${LINE}" ".*;\(.*\);.*")" # nie je nutne pouzit prikaz cd, kedze pracujeme s absolutnymi cestami. mkdir "${CESTA}" cp "${SOUBOR}".zip "${CESTA}" unzip -P "${HESLO}" "${SOUBOR}".zip rm -rvf "${SOUBOR}".zip done < "${SEZNAM}"
# nie je nutne pouzit prikaz cd, kedze pracujeme s absolutnymi cestami. mkdir "${CESTA}" cp "${SOUBOR}".zip "${CESTA}" unzip -P "${HESLO}" "${SOUBOR}".zipV zipu nebudou absolutní cesty, takže cd (nebo parametr zipu
-d
) je nutné, výchozí chování je rozbalovat do aktuálního adresáře, ne do adresáře se zipem. Spíš není nutné to kopírování:
mkdir "${CESTA}" && unzip -P "${HESLO}" -d "${CESTA}" "${SOUBOR}.zip" && rm -rvf "${SOUBOR}.zip"
-r
jsem tam dal jen vinou copy&paste, ale u souboru samozř. není potřeba.
Mohol som to dopisat kompletne, ale nedopisal som a bol na to dovod. Z toho titulu si nemyslim, ze mi usla pointa alebo nieco v tom zmysle. Ja sam by som testoval existenciu adresarov, ich prava atd. Ak si vsimnete, tak je tam prave toto napisane v komente priamo v skripte. Ja som nechcel vsetko spravit za neho, kedze od doby, kedy zalozil temu, tu prezentoval aj svoj vlastny progres v tejto veci. Tak som mu chcel dat priestor aj na sebarealizaciu. O vyuziti pozicnych parametroch tam nebolo nic v jeho povodnom skripte, to som teda napisal. Dalej vsak isiel spravne, tak som predpokladal, ze to chape a teda mu bude jednoduche upravit prave tu cast, aby kontrolovalo existenciu, opravnenia, atd. v slucke while.
if [[ -r soubor.txt ]]; then while read line; do foo done < soubor.txtje totéž, jako
while read line; do foo done < soubor.txtakorát druhá varianta vám řekne
line 3: soubor.txt: No such file or directory
zatímco ta první tiše selže. Takže buď můžete kontrolovat a psát vlastní chybová hlášení, nebo to nechat na bashi. Mnoho věcí na bashi nechat lze. Závislost mezi příkazy (unzip file.zip && rm file.zip) nikoliv, TO je potřeba ošetřit.
Dakujem za tip. Takto som nad kontrolou suboru, ci je citatelny pre sluckou while, nikdy nepremyslal. To sa isto zide. ;) Samozrejme suhlasim aj s ostatkom.
Ako som uz povedal, chyby tam mozu byt a nasli sa. Stravil som nad tym dakych 15 minut a ziadne otestovanie. Moj postup bol prepis povodneho skriptu a neuvedomil som si, ze unzip to rozbali uplne niekde inde. Moja chyba.
readlink -f
zipu v ničem nepomůže a s použitím cd
to nesouvisí. Nebo jsem vás asi nepochopil. Proto jsem to považoval za vhodné zmínit.
Ostatní věci jako absence kontroly úspěšnosti unzip
nebo cp
dřív, než originální zip smažu, bych nepovažoval za nepozornost či únavu po 15 minutách ošetřování vstupů, ale za hrubou chybu ;) Samozřejmě je to subjektivní, hlavně zálohovat :D
Hruba chyba urcite by to bola, ale tu som to neosetril prave skrz toho, ze som to chcel nechat na zakladatela a tak som to aj poznamenal v komente v skripte. Akokolvek, tento vas nazor nie je ani tak subjektivny ako objektivny. ;)
#!/bin/bash while IFS=';' read cesta heslo soubor; do mkdir -p "$cesta" cd "$cesta" unzip -P "$heslo" "../$soubor.zip" cd - done <seznam.txt
#!/bin/bash while IFS=';' read cesta heslo soubor; do mkdir -p "$cesta" && unzip -P "$heslo" -d "$cesta" "$soubor.zip" done < seznam.txt
Tiskni
Sdílej: