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 16:33 | Humor

    Je tu opět apríl. O víkendu zmizel kamion s 12 tunami tyčinek KitKat. Firmy to využívají k aprílovým žertům. Groupon má super akci. Koupíte 1 tyčinku a dostanete 100 zdarma. Ryanair si přelepil letadla. Šéf Outlooku se ptá, proč mají v baráku 14 beden tyčinek KitKat (𝕏). Prusa Research představuje Prusa Pro ACU a vysvětluje proč přílišné sušení škodí vaším filamentům. Telefon Sony Xperia má miliónnásobný zoom (𝕏). PC.net představil Super Ultrabox 2600 se zajímavými parametry. Další aprílové novinky například na April Fools' Day On The Web.

    Ladislav Hagara | Komentářů: 2
    dnes 13:22 | IT novinky

    Společnost OpenAI, která stojí za chatovacím robotem s umělou inteligencí (AI) ChatGPT, získala od investorů 122 miliard USD (2,6 bilionu Kč). Hodnota společnosti tak dosáhla 852 miliard dolarů (více než 18 bilionů Kč). Nejnovější kolo investování se stalo největší, jaké zatím firma uskutečnila, a peníze mají posílit ambiciózní plány rozšíření výpočetní kapacity, datových center a nábor talentů.

    Ladislav Hagara | Komentářů: 3
    dnes 13:11 | IT novinky

    Nástroj k identifikaci občanů v on-line komunikaci s úřady byl dnes dopoledne zhruba dvě hodiny částečně nedostupný. Problém se objevil kolem 09:00 a podařilo se ho vyřešit kolem 11:00. Částečně nedostupná byla služba Národní identitní autority (NIA), problémy podle DIA (Digitální a informační agentura) ovlivňovaly přihlašování například i přes bankovní identitu. „Dostupnost NIA byla plně obnovena, přihlášení k digitálním službám

    … více »
    Ladislav Hagara | Komentářů: 2
    dnes 13:00 | IT novinky

    Eben Upton oznámil další zdražení počítačů Raspberry Pi kvůli růstu cen pamětí a představil Raspberry Pi 4 s 3 GB RAM za 83,75 dolarů.

    Ladislav Hagara | Komentářů: 0
    dnes 04:33 | Humor

    Anthropic patrně omylem zveřejnil celý zdrojový kód svého CLI nástroje Claude Code prostřednictvím přiloženého sourcemap souboru v npm balíčku. Únik odhalil doposud nijak nezveřejněné funkce jako je například režim v utajení, autonomní agent 'KAIROS', orchestrace multi‑agentů, režim snění nebo dokonce virtuální mazlíček Buddy. Zajímavostí je detekce naštvání uživatele pomocí obyčejného regexpu. Anthropic rychle odstranil sourcemap a vydal opravu, nicméně kopie kódu se již stihly na GitHubu rozšířit mezi prostým lidem.

    NUKE GAZA! 🎆 | Komentářů: 10
    včera 14:33 | Humor

    Copilot automaticky vkládal do pull requestů 'propagační tipy', reklamní text se na GitHubu objevil ve více než jedenácti tisících pull requestech. Po vlně kritiky byla tato funkce zablokována a produktový manažer Tim Rogers připustil, že umožnit Copilotovi upravovat cizí pull requesty bez vědomí autorů byla chyba.

    NUKE GAZA! 🎆 | Komentářů: 4
    včera 12:55 | Upozornění

    Je 31. března a tedy Světový den zálohování (World Backup Day). Co by se stalo, kdyby Vám právě teď odešel počítač, tablet nebo telefon, který používáte?

    Ladislav Hagara | Komentářů: 4
    včera 12:44 | Upozornění

    Digitální a informační agentura (DIA) přistupuje ke změně formátu důvěryhodného seznamu České republiky z verze TLv5 na verzi TLv6, která nastane 29. dubna 2026 v 00:00 (CET). Ke změně formátu důvěryhodných seznamů členských států (tzv. Trusted Lists) dochází na základě změn příslušné unijní legislativy. Důvěryhodné seznamy se používají v rámci informačních systémů a aplikací zejména pro účely ověřování platnosti elektronických

    … více »
    Ladislav Hagara | Komentářů: 2
    včera 05:00 | Nová verze

    Rspamd (Wikipedie), tj. open source systému pro filtrování nevyžádané pošty, byl vydán v nové major verzi 4.0.0. Přehled novinek v Changelogu.

    Ladislav Hagara | Komentářů: 1
    30.3. 23:11 | Nová verze

    SolveSpace (Wikipedie), tj. multiplatformní open source parametrický 2D/3D CAD, byl vydán v nové verzi 3.2. Přehled novinek v Changelogu na GitHubu. Vyzkoušet lze novou oficiální webovou verzi.

    Ladislav Hagara | Komentářů: 10
    Které desktopové prostředí na Linuxu používáte?
     (15%)
     (7%)
     (1%)
     (12%)
     (30%)
     (3%)
     (5%)
     (1%)
     (14%)
     (23%)
    Celkem 1202 hlasů
     Komentářů: 29, poslední včera 11:17
    Rozcestník

    Dotaz: for a dvě pole

    11.1.2011 01:01 jsk | skóre: 10
    for a dvě pole
    Přečteno: 425×

    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

    Odpovědi

    11.1.2011 08:33 Šangala | skóre: 56 | blog: Dutá Vrba - Wally
    Rozbalit Rozbalit vše Re: for a dvě pole
    Pomůže toto:?
    #!/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
    
    Pro oddělovač řádků místo mezery:
    IFS="
    "
    To, že trpíš stihomamem, ještě neznamená, že po tobě nejdou. ⰞⰏⰉⰓⰀⰜⰉ ⰗⰞⰅⰜⰘ ⰈⰅⰏⰉ ⰒⰑⰎⰉⰁⰕⰅ ⰏⰉ ⰒⰓⰄⰅⰎ ·:⁖⁘⁙†
    David Watzke avatar 11.1.2011 08:47 David Watzke | skóre: 74 | blog: Blog... | Praha
    Rozbalit Rozbalit vše Re: for a dvě pole
    Počet prvků je takhle:
    ${#ARR1[*]}
    nebo případně
    ${#ARR1[@]}
    “Being honest may not get you a lot of friends but it’ll always get you the right ones” ―John Lennon
    11.1.2011 10:35 Šangala | skóre: 56 | blog: Dutá Vrba - Wally
    Rozbalit Rozbalit vše Re: for a dvě pole
    Sorry, to byla chyba při záměně za HTML entity (proč jsem vyměnil @ za &amp;, nevím) :(
    Oprava:
    #!/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
    
    To, že trpíš stihomamem, ještě neznamená, že po tobě nejdou. ⰞⰏⰉⰓⰀⰜⰉ ⰗⰞⰅⰜⰘ ⰈⰅⰏⰉ ⰒⰑⰎⰉⰁⰕⰅ ⰏⰉ ⰒⰓⰄⰅⰎ ·:⁖⁘⁙†
    11.1.2011 11:09 Patrik Uhrak | skóre: 31 | blog: pato
    Rozbalit Rozbalit vše Re: for a dvě pole

    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.

    
                
    11.1.2011 12:13 Patrik Uhrak | skóre: 31 | blog: pato
    Rozbalit Rozbalit vše Re: for a dvě pole

    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.).

    12.1.2011 06:14 jsk | skóre: 10
    Rozbalit Rozbalit vše Re: for a dvě pole

    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

    12.1.2011 08:19 Šangala | skóre: 56 | blog: Dutá Vrba - Wally
    Rozbalit Rozbalit vše Re: for a dvě pole
    Učím se rozumět řeči tvého kmene, dává toto co je třeba? :):
    #!/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
    
    
    To, že trpíš stihomamem, ještě neznamená, že po tobě nejdou. ⰞⰏⰉⰓⰀⰜⰉ ⰗⰞⰅⰜⰘ ⰈⰅⰏⰉ ⰒⰑⰎⰉⰁⰕⰅ ⰏⰉ ⰒⰓⰄⰅⰎ ·:⁖⁘⁙†
    David Watzke avatar 11.1.2011 20:14 David Watzke | skóre: 74 | blog: Blog... | Praha
    Rozbalit Rozbalit vše Re: for a dvě pole
    To s tím unsetem je to slušná chlívárna, radši použij for a nic "neunsetuj".
    “Being honest may not get you a lot of friends but it’ll always get you the right ones” ―John Lennon
    11.1.2011 23:30 Patrik Uhrak | skóre: 31 | blog: pato
    Rozbalit Rozbalit vše Re: for a dvě pole

    Tiez si myslim. ;(

    11.1.2011 22:05 jsk | skóre: 10
    Rozbalit Rozbalit vše Re: for a dvě pole

    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

    11.1.2011 22:39 Šangala | skóre: 56 | blog: Dutá Vrba - Wally
    Rozbalit Rozbalit vše Re: for a dvě pole
    Nemluvím [plně řečí tvého kmene, ale pomůže?:
    #!/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
    
    
    To, že trpíš stihomamem, ještě neznamená, že po tobě nejdou. ⰞⰏⰉⰓⰀⰜⰉ ⰗⰞⰅⰜⰘ ⰈⰅⰏⰉ ⰒⰑⰎⰉⰁⰕⰅ ⰏⰉ ⰒⰓⰄⰅⰎ ·:⁖⁘⁙†
    11.1.2011 23:12 jsk | skóre: 10
    Rozbalit Rozbalit vše Re: for a dvě pole

    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

    11.1.2011 23:44 Šangala | skóre: 56 | blog: Dutá Vrba - Wally
    Rozbalit Rozbalit vše Re: for a dvě pole
    if [ $i -lt ${CNT2} ]; then
      #dělej toto pokud $i je menší (l-ower t-hen) než $CNT
      #viz man test
    fi
    
    No 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.
    Oprava:
    #!/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 0
    
    Vlastni 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
    
    To, že trpíš stihomamem, ještě neznamená, že po tobě nejdou. ⰞⰏⰉⰓⰀⰜⰉ ⰗⰞⰅⰜⰘ ⰈⰅⰏⰉ ⰒⰑⰎⰉⰁⰕⰅ ⰏⰉ ⰒⰓⰄⰅⰎ ·:⁖⁘⁙†
    11.1.2011 23:45 Patrik Uhrak | skóre: 31 | blog: pato
    Rozbalit Rozbalit vše Re: for a dvě pole

    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

    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.