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 15:33 | Komunita

    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.

    Ladislav Hagara | Komentářů: 0
    dnes 12:44 | Nová verze

    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.

    Ladislav Hagara | Komentářů: 0
    dnes 12:22 | Nová verze

    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.

    Ladislav Hagara | Komentářů: 0
    dnes 01:22 | Nová verze

    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.

    Ladislav Hagara | Komentářů: 0
    včera 15:11 | Bezpečnostní upozornění

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

    Ladislav Hagara | Komentářů: 5
    včera 14:00 | IT novinky

    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.

    Ladislav Hagara | Komentářů: 16
    včera 12:33 | Zajímavý software

    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.

    Ladislav Hagara | Komentářů: 0
    včera 03:33 | IT novinky

    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.

    Ladislav Hagara | Komentářů: 0
    7.10. 18:11 | Nová verze

    Programovací jazyk Python byl vydán v nové major verzi 3.14.0. Podrobný přehled novinek v aktualizované dokumentaci.

    Ladislav Hagara | Komentářů: 2
    7.10. 16:33 | IT novinky

    Bylo oznámeno, že Qualcomm kupuje Arduino. Současně byla představena nová deska Arduino UNO Q se dvěma čipy: MPU Qualcomm Dragonwing QRB2210, na kterém může běžet Linux, a MCU STM32U585 a vývojové prostředí Arduino App Lab.

    Ladislav Hagara | Komentářů: 4
    Jaké řešení používáte k vývoji / práci?
     (39%)
     (46%)
     (15%)
     (17%)
     (21%)
     (15%)
     (17%)
     (15%)
     (15%)
    Celkem 201 hlasů
     Komentářů: 13, poslední včera 07:41
    Rozcestník
    Štítky: není přiřazen žádný štítek

    Dotaz: Jak rekurzivně spočítat všechny položky v adresáři.

    6.2.2019 10:52 ferda
    Jak rekurzivně spočítat všechny položky v adresáři.
    Přečteno: 542×
    Ahoj, Potřebuji rekurzivně spočítat všechny položky v adresáři a našel jsem tohle. Nejde to prosím napsat tak, aby to prohledával jen jednou?

    d=$(find . -type d | wc -l)
    f=$(find . -type f | wc -l)
    echo "There are $d directories and $f files"

    Odpovědi

    6.2.2019 11:12 ondrejd
    Rozbalit Rozbalit vše Re: Jak rekurzivně spočítat všechny položky v adresáři.
    6.2.2019 11:16 ferda
    Rozbalit Rozbalit vše Re: Jak rekurzivně spočítat všechny položky v adresáři.
    Moc děkuji.
    6.2.2019 12:56 Andrej | skóre: 51 | blog: Republic of Mordor
    Rozbalit Rozbalit vše Re: Jak rekurzivně spočítat všechny položky v adresáři.

    Účelem domácího úkolu je, aby se nad ním student sám zamyslel, ne aby se na něj anonymně ptal na ABCLinuxu. :-(

    Zpět k tématu: Jde to dokonce i bez jakýchkoliv externích procesů (ls, find), pouze pomocí Bashe. Jediné, na co je třeba si dát pozor, je zvláštní chování find k symlinkům. Implicitně (-P) je nenásleduje (což se dá změnit pomocí -L), zatímco Bash při testování cest symlinky vždy následuje, jinými slovy, máme-li symlink na soubor, [[ -f symlink ]] i [[ -L symlink ]] uspějí.

    Pokud tohle^^^ vezmeme v potaz, tady je implementace jen pomocí Bashe a ničeho jiného:

    rlist() {
      local -r dir="$1"
      local -i files=0
      local -i dirs=1
      local -i links=0
      local -i other=0
      local -a -i rec
      local item
      for item in "${dir}/"{,.[^.],..?}*; do
        if [[ -L "$item" ]]; then
          ((++links))
        elif [[ -f "$item" ]]; then
          ((++files))
        elif [[ -d "$item" ]]; then
          rec=($(rlist "$item"))
          files+=rec[0]
          dirs+=rec[1]
          links+=rec[2]
          other+=rec[3]
        elif [[ -e "$item" ]]; then
          ((++other))
        fi
      done
      echo "$files" "$dirs" "$links" "$other"
    }
    
    count() {
      local -a -i -r rec=($(rlist "$1"))
      echo "There are ${rec[1]} directories" \
           "and ${rec[0]} files" \
           "and ${rec[2]} symlinks" \
           "and ${rec[3]} other inodes."
    }
    

    Příklad: count /můj/adresář

    Implementace ekvivalentu find -L by byla jednoduší; stačilo by odstranit větev a proměnnou pro symlinky.

    6.2.2019 13:45 NN
    Rozbalit Rozbalit vše Re: Jak rekurzivně spočítat všechny položky v adresáři.
    No to je sice fajn, ze to zvladnes ciste v bashi Andreji, ale pokud tazatel resi problem na urovni "hledani na internetu", je uplne jedno jestli je to ukol nebo neni, tak to naopak jen odradi od dalsiho usili a snazeni..
    6.2.2019 14:01 Aleš Kapica | skóre: 52 | blog: kenyho_stesky | Ostrava
    Rozbalit Rozbalit vše Re: Jak rekurzivně spočítat všechny položky v adresáři.
    …je uplne jedno jestli je to ukol nebo neni, tak to naopak jen odradi od dalsiho usili a snazeni..
    Pokud někdo není ochoten věnovat tomu aby se něco naučil trochu toho úsilí a snažení, tak bude jen dobře když skončí u OS, kde si za svou lenost zaplatí.
    6.2.2019 14:43 .
    Rozbalit Rozbalit vše Re: Jak rekurzivně spočítat všechny položky v adresáři.
    Jinak zdravej?
    6.2.2019 14:46 Aleš Kapica | skóre: 52 | blog: kenyho_stesky | Ostrava
    Rozbalit Rozbalit vše Re: Jak rekurzivně spočítat všechny položky v adresáři.
    Nestěžuji si. Děkuji za optání. Po vás taky žádná sháňka nebude.
    6.2.2019 21:07 Andrej | skóre: 51 | blog: Republic of Mordor
    Rozbalit Rozbalit vše Re: Jak rekurzivně spočítat všechny položky v adresáři.
    1. O jakém úsilí a snažení je řeč? Žádné jsem na straně tazatele nezaznamenal — snad kromě toho, že některé své dotazy duplikuje v poradně na lživě.cz.
    2. Proč by mě mělo jakkoliv znepokojovat, že tohle někoho odradí? Popsal jsem řešení, které podle mého mínění splňuje zadání (jeden průchod) a funguje. Dokonce jsem — kromě postesknutí nad domácím úkolem „řeseným“ v poradně — tentokrát udržel svou obvyklou aroganci celkem na uzdě. Pokud mé řešení samo od sebe někoho odradí od „snažení“, možná pro takového člověka není informatika / IT správná volba.

    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.