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 13:44 | Nová verze

Bylo vydáno Ubuntu 17.10 s kódovým názvem Artful Aardvark. Ke stažení jsou Ubuntu Desktop a Server, Ubuntu Cloud Images, Ubuntu Netboot, Kubuntu, Lubuntu a Lubuntu Alternate, Lubuntu Next, Ubuntu Budgie, Ubuntu Kylin, Ubuntu MATE, Ubuntu Studio a Xubuntu. Podrobnosti v poznámkách k vydání.

Ladislav Hagara | Komentářů: 0
dnes 13:00 | Komunita

MojeFedora.cz informuje, že Fedora 27 dostane podporu pro AAC. Podpora multimediálních formátů je ve výchozí instalaci Fedory tradičně limitovaná kvůli softwarovým patentům, ale desktopový tým Red Hatu se ji i tak snaží v poslední době co nejvíce rozšířit. Už nějaký čas obsahuje kodeky pro MP3, H.264, AC3 a nyní byl přidán také kodek pro další velmi rozšířený zvukový formát – AAC.

Ladislav Hagara | Komentářů: 0
včera 23:55 | Pozvánky

Spolek OpenAlt zve příznivce otevřených technologií a otevřeného přístupu na 145. brněnský sraz, který proběhne v pátek 20. října od 18:00 hodin v restauraci Time Out na adrese Novoměstská 2 v Řečkovicích. Jedná se o poslední sraz před konferencí OpenAlt 2017, jež proběhne o víkendu 4. a 5. listopadu 2017 na FIT VUT v Brně. Běží registrace účastníků.

Ladislav Hagara | Komentářů: 0
včera 21:44 | Nová verze

Byla vydána verze 5.2.0 multiplatformního virtualizačního nástroje Oracle VM VirtualBox. Jedná se o první stabilní verzi z nové větve 5.2. Z novinek lze zmínit například možnost exportování VM do Oracle Cloudu, bezobslužnou instalaci hostovaného systému nebo vylepšené GUI. Podrobnosti v seznamu změn. Aktualizována byla také dokumentace.

Ladislav Hagara | Komentářů: 1
včera 14:00 | Zajímavý projekt

Byl spuštěn Humble Down Under Bundle. Za vlastní cenu lze koupit multiplatformní hry The Warlock of Firetop Mountain, Screencheat, Hand of Fate a Satellite Reign. Při nadprůměrné platbě (aktuálně 3,63 $) také Hacknet, Hacknet Labyrinths, Crawl a Hurtworld. Při platbě 12 $ a více lze získat navíc Armello.

Ladislav Hagara | Komentářů: 0
včera 13:00 | Nová verze

Google Chrome 62 byl prohlášen za stabilní (YouTube). Nejnovější stabilní verze 62.0.3202.62 tohoto webového prohlížeče přináší řadu oprav a vylepšení. Vylepšeny byly také nástroje pro vývojáře (YouTube). Opraveno bylo 35 bezpečnostních chyb.

Ladislav Hagara | Komentářů: 4
včera 11:00 | Zajímavý článek

Článek (en) na Mozilla.cz je věnován vykreslování stránek ve Firefoxu. V průběhu roku 2018 by se ve Firefoxu měl objevit WebRender, jenž by měl vykreslování stránek urychlit díky využití GPU.

Ladislav Hagara | Komentářů: 5
včera 08:22 | Bezpečnostní upozornění

NÚKIB (Národní úřad pro kybernetickou a informační bezpečnost) informuje o zranitelnosti ROCA v procesu generování RSA klíčů, který se odehrává v softwarové knihovně implementované například v kryptografických čipových kartách, bezpečnostních tokenech a dalších hardwarových čipech vyrobených společností Infineon Technologies AG. Zranitelnost umožňuje praktický faktorizační útok, při kterém útočník dokáže vypočítat

… více »
Ladislav Hagara | Komentářů: 3
včera 01:23 | Zajímavý software

Příspěvek na blogu otevřené certifikační autority Let's Encrypt informuje o začlenění podpory protokolu ACME (Automatic Certificate Management Environment) přímo do webového serveru Apache. Klienty ACME lze nahradit novým modulem Apache mod_md. Na vývoj tohoto modulu bylo uvolněno 70 tisíc dolarů z programu Mozilla Open Source Support (MOSS). K rozchození HTTPS na Apache stačí nově přidat do konfiguračního souboru řádek s ManagedDomain. Minutový videonávod na YouTube [reddit].

Ladislav Hagara | Komentářů: 4
17.10. 14:15 | Komunita

Daniel Stenberg, autor nástroje curl, na svém blogu oznámil, že obdržel letošní Polhemovu cenu, kterou uděluje Švédská inženýrská asociace za „technologickou inovaci nebo důvtipné řešení technického problému“.

marbu | Komentářů: 11
Jak se vás potenciálně dotkne trend odstraňování analogového audio konektoru typu 3,5mm jack z „chytrých telefonů“?
 (11%)
 (1%)
 (1%)
 (1%)
 (74%)
 (13%)
Celkem 95 hlasů
 Komentářů: 5, poslední dnes 07:28
    Rozcestník

    Dotaz: for a dvě pole

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

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