Byl vydán Nextcloud Hub 8. Představení novinek tohoto open source cloudového řešení také na YouTube. Vypíchnout lze Nextcloud AI Assistant 2.0.
Vyšlo Pharo 12.0, programovací jazyk a vývojové prostředí s řadou pokročilých vlastností. Krom tradiční nadílky oprav přináší nový systém správy ladících bodů, nový způsob definice tříd, prostor pro objekty, které nemusí procházet GC a mnoho dalšího.
Microsoft zveřejnil na GitHubu zdrojové kódy MS-DOSu 4.0 pod licencí MIT. Ve stejném repozitáři se nacházejí i před lety zveřejněné zdrojové k kódy MS-DOSu 1.25 a 2.0.
Canonical vydal (email, blog, YouTube) Ubuntu 24.04 LTS Noble Numbat. Přehled novinek v poznámkách k vydání a také příspěvcích na blogu: novinky v desktopu a novinky v bezpečnosti. Vydány byly také oficiální deriváty Edubuntu, Kubuntu, Lubuntu, Ubuntu Budgie, Ubuntu Cinnamon, Ubuntu Kylin, Ubuntu MATE, Ubuntu Studio, Ubuntu Unity a Xubuntu. Jedná se o 10. LTS verzi.
Na YouTube je k dispozici videozáznam z včerejšího Czech Open Source Policy Forum 2024.
Fossil (Wikipedie) byl vydán ve verzi 2.24. Jedná se o distribuovaný systém správy verzí propojený se správou chyb, wiki stránek a blogů s integrovaným webovým rozhraním. Vše běží z jednoho jediného spustitelného souboru a uloženo je v SQLite databázi.
Byla vydána nová stabilní verze 6.7 webového prohlížeče Vivaldi (Wikipedie). Postavena je na Chromiu 124. Přehled novinek i s náhledy v příspěvku na blogu. Vypíchnout lze Spořič paměti (Memory Saver) automaticky hibernující karty, které nebyly nějakou dobu používány nebo vylepšené Odběry (Feed Reader).
OpenJS Foundation, oficiální projekt konsorcia Linux Foundation, oznámila vydání verze 22 otevřeného multiplatformního prostředí pro vývoj a běh síťových aplikací napsaných v JavaScriptu Node.js (Wikipedie). V říjnu se verze 22 stane novou aktivní LTS verzí. Podpora je plánována do dubna 2027.
Byla vydána verze 8.2 open source virtualizační platformy Proxmox VE (Proxmox Virtual Environment, Wikipedie) založené na Debianu. Přehled novinek v poznámkách k vydání a v informačním videu. Zdůrazněn je průvodce migrací hostů z VMware ESXi do Proxmoxu.
R (Wikipedie), programovací jazyk a prostředí určené pro statistickou analýzu dat a jejich grafické zobrazení, bylo vydáno ve verzi 4.4.0. Její kódové jméno je Puppy Cup.
Dobrý den,
potřeboval bych poradit jak zjednodušit násl. úlohu tak, aby pro každou hodnotu z dvojice $prvni
a $druhy
nemusel vypisovat vlastní for
pro všechny indexy.
prvni=(`cat soubor1`)
druhy=(`cat soubor2`)
for ikx in $( seq ${prvni[0]} )
do 'třeba wget' "${ikx}${druhy[0]}"
done
$prvni
a $druhy
mají stejný počet hodnot, $prvni
je cele kladné číslo a $druhy
je text.
Měl jsem dojem, že by šlo využít toho, že hodnoty indexu jsou pro jednotlivé cykly for
stejné, ale to mi přišlo jako speciální případ a zatím ani nevím jak na to.
S načítanými soubory (soubor1
a soubor2
) mohu volně manipulovat a případně je přizpůsobit.
Předem všem děkuji!
jsk
#!/bin/bash #vstup IN1="kuk baf bum" IN2="KUK BAF BUM" #priprava pole saveIFS=$IFS IFS=" " ARR1=( $IN1 ) ARR2=( $IN2 ) IFS=$saveIFS #pocet prvku CNT=${#ARR1[&]} #kontrola prvku v obou polich if [ ${CNT} -ne ${#ARR2[&]} ]; then echo "Error: cnt1 != cnt2" exit 3 fi #zpracovani for (( i=0; i<${CNT}; i++ )); do echo "${ARR1[$i]} - ${ARR2[$i]} " done exit 0Pro oddělovač řádků místo mezery:
IFS=" "
${#ARR1[*]}nebo případně
${#ARR1[@]}
#!/bin/bash #vstup IN1="kuk baf bum" IN2="KUK BAF BUM" #priprava pole saveIFS=$IFS IFS=" " ARR1=( $IN1 ) ARR2=( $IN2 ) IFS=$saveIFS #pocet prvku CNT=${#ARR1[@]} #kontrola prvku v obou polich if [ ${CNT} -ne ${#ARR2[@]} ]; then echo "Error: cnt1 != cnt2" exit 3 fi #zpracovani for (( i=0; i<${CNT}; i++ )); do echo "${ARR1[$i]} - ${ARR2[$i]} " done exit 0
Zdravim,
ja tu mam tiez jedno riesenie a ci idealne, tak to zalezi na okolnostiach:
#! /bin/bash
mapfile -t PRVNI <./soubor1
mapfile -t DRUHY <./soubor2
while [[ -n "${PRVNI[0]}" && ${#PRVNI[@]} -eq ${#DRUHY[@]} ]]
do
echo "Aktualna dvojica: ${PRVNI[0]} - ${DRUHY[0]}"
unset PRVNI[0]
PRVNI=( ${PRVNI[@]} )
unset DRUHY[0]
DRUHY=( ${DRUHY[@]} )
done
Vyhody: Aj napriek nerovnakemu poctu clenov v jednom ci druhom subore,f popari, co sa da a az ked nenajde dvojicu, skonci. Co je zaroven jediny mozny koniec.
Nevyhody: Polia budu na konci cyklu prazdne a teda pri voli dalsieho pouzitia by bolo znova nutne nacitat zo suboru (velmi zle :)) . Toto sa da obist za cenu vytvorenia docasnych poli. Pre kazde jedno povodne vytvorit jedno docasne priamo vo funkcii. Pole bude platne len v ramci funkcie. PRVNI_TMP=( ${PRVNI[@]} )
#! /bin/bash
Prirad()
{
declare -a PRVNI_TMP=( ${PRVNI[@]} )
declare -a DRUHY_TMP=( ${DRUHY[@]} )
while [[ -n "${PRVNI_TMP[0]}" && ${#PRVNI_TMP[@]} -eq ${#DRUHY_TMP[@]} ]]
do
echo "Aktualna dvojica: ${PRVNI_TMP[0]} - ${DRUHY_TMP[0]}"
unset PRVNI_TMP[0]
PRVNI_TMP=( ${PRVNI_TMP[@]} )
unset DRUHY_TMP[0]
DRUHY_TMP=( ${DRUHY_TMP[@]} )
done
}
mapfile -t PRVNI <./soubor1
mapfile -t DRUHY <./soubor2
Prirad
Nevravim, ze idealne, ale riesenie to je.
Oprava:
Cyklus ma byt nasledovne:
while [[ -n "${PRVNI[0]}" && -n "${DRUHY[0]}" ]]
aby to malo tu mnou spominanu "vyhodu". Je nutne vediet, ci tie dva prvky z prveho a druheho pola maju nejaku spojitost (meno a priezvisko a pod.).
Zdravím,
pokusím se vysvětlit souvislost prvků mám-li např.
S1=(1 2 3 4 7 8 9 10 11)
a
S2=(100 83 150 230 11 18 22 55 99)
pro S1[0]
se provede činnost 100×
Asi jsem to původně popsal dost neobratně
jsk
#!/bin/bash #vstup IN1="kuk baf bum klof nic nic2" IN2="3 1 7 2 pepa" #priprava pole saveIFS=$IFS IFS=" " ARR1=( $IN1 ) ARR2=( $IN2 ) IFS=$saveIFS #pocet prvku CNT1=${#ARR1[@]} CNT2=${#ARR2[@]} if [ ${CNT2} -lt ${CNT1} ]; then MAX=${CNT2} else MAX=${CNT1} fi #zpracovani for (( i=0; i<${MAX}; i++ )); do NUM_MAX=$(( ${ARR2[$i]} + 0 )) for (( j=0; j<${NUM_MAX}; j++ )); do echo "${ARR1[$i]} - $(($j+1))" done done exit 0
Tiez si myslim. ;(
Zdravím a děkuji všem,
nejsem si zcela jistý, že jsem problém správně popsal, pro hodnotu na pozici v $soubor1
potřebuji, aby proběhlo zpracování pro všechny hodnoty v rozsahu od 1 až po hodnotu stejné pozice v soubor2
, takže na jeden průchod prvním for
potřebuji více průchodů ve druhém for
.
Měl jsem na mysli jako něco viz. níže, ale to mi nepokryje v druhém cyklu všechny případy, prostě mi to nepodrží zet
. 20 = počet řádků.
prvni=(`cat soubor1`)
druhy=(`cat soubor2`)
then for zet in ( 1 2 ... 20} )
do for ikx in $( seq ${prvni[$zet]} ) ; do 'třeba wget' "neco${ikx}a_neco_jineho${druhy[$zet]}" ; done
done
Dostal jsem se k domácímu kompu teprve teď, takže jsem se možná ne všechny hned reakce pochopil správně, používám BASH nárazově a moc toho zatím neumím.
jsk
#!/bin/bash #vstup IN1="kuk baf bum bac snup nic" IN2="KUK BAF BUM BAC SNUP" #priprava pole saveIFS=$IFS IFS=" " ARR1=( $IN1 ) ARR2=( $IN2 ) IFS=$saveIFS #pocet prvku CNT1=${#ARR1[@]} CNT2=${#ARR2[@]} #zpracovani for (( i=0; i<${CNT1}; i++ )); do if [ $i -lt ${CNT2} ]; then for (( j=0; jlt;=i; j++ )); do echo "${ARR1[$i]} - ${ARR2[$j]}" done fi done exit 0
Díky,
asi to není úplně snadné porozumět tomu co jsem napsal :(, snažil jsem se to popsat obecně, abych se nedobral k řešení postaveném na něčem zcela specifickém a mimochodem jsem to v pův. zadání napsal špatně, na vstupu jsou čísla.
Nerozumím úplně řádkům 19 a 20 hlavně -lt
a jlt;=i
mi není jasné, IFS jsem zřejmě již pochopil, ale vypadá to, že je to ono, pro každé i
se provede j
průchodů a i
i j
mohu vložit jako proměnou do url které dávám wget-u, zde echo.
Konkrétní test provedu až zítra, teď už musím končit, ještě jednou děkuji!!
Zdraví jsk
if [ $i -lt ${CNT2} ]; then #dělej toto pokud $i je menší (l-ower t-hen) než $CNT #viz man test fiNo k 20tému řádku, nevím jak to dneska dělám ale již podruhé v této diskuzi při záměně znaků za html entity to nějak sprasím.
#!/bin/bash #vstup IN1="kuk baf bum bac snup nic" IN2="KUK BAF BUM BAC SNUP" #priprava pole saveIFS=$IFS IFS=" " ARR1=( $IN1 ) ARR2=( $IN2 ) IFS=$saveIFS #pocet prvku CNT1=${#ARR1[@]} CNT2=${#ARR2[@]} #zpracovani for (( i=0; i<${CNT1}; i++ )); do if [ $i -lt ${CNT2} ]; then for (( j=0; j<=$i; j++ )); do echo "${ARR1[$i]} - ${ARR2[$j]}" done fi done exit 0Vlastni for může být realizovan i takto, přijde na to co se má stát když nemají pole stejný počet prvků.
#zpracovani for (( i=0; i<${CNT1}; i++ )); do if [ $i -lt ${CNT2} ]; then k=$i else k=$((${CNT2} - 1)) fi for (( j=0; j<=$k; j++ )); do echo "${ARR1[$i]} - ${ARR2[$j]}" done done
Zdravim,
19. riadok : -lt , -gt , -le, -ge, -ne, -eq : su pre porovnavanie celociselnych hodnot (integer)
20. riadok : Tam je preklep, spravne by mal byt takto zrejme: for (( j=0; j<=${i}; j++ )); do
Tiskni Sdílej: