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 14:55 | Zajímavý článek

Nová čísla časopisů od nakladatelství Raspberry Pi: MagPi 81 (pdf), HackSpace 18 (pdf), Hello World 8 (pdf) a Wireframe 11 (pdf) a 12 (pdf).

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

Po více než 4 měsících vývoje od vydání verze 15 byla vydána nová stabilní verze 16 open source systému Nextcloud (Wikipedie), forku ownCloudu, umožňujícího provoz vlastního cloudového úložiště. Přehled novinek i s náhledy v příspěvku na blogu. Pro vyzkoušení Nextcloudu je k dispozici demo (aktuálně verze 15).

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

Node.js Foundation, oficiální projekt konsorcia Linux Foundation, oznámila vydání verze 12.0.0 (Current) otevřeného multiplatformního prostředí pro vývoj a běh síťových aplikací napsaných v JavaScriptu Node.js (Wikipedie). Přehled novinek v článku na Medium. Verze 12 se v říjnu stane novou aktivní LTS verzí. Podpora je plánována do dubna 2022.

Ladislav Hagara | Komentářů: 1
dnes 00:44 | Nová verze

Byla vydána verze 11.10 open source alternativy GitHubu, tj. softwarového nástroje s webovým rozhraním umožňujícího spolupráci na zdrojových kódech, GitLab (Wikipedie). Představení nových vlastností i s náhledy v příspěvku na blogu.

Ladislav Hagara | Komentářů: 0
dnes 00:11 | IT novinky

OpenAI, nezisková organizace pro výzkum umělé inteligence (AI), představila projekt MuseNet. Jedná se o hlubokou neuronovou síť, která dokáže generovat čtyřminutové hudební skladby s 10 různými nástroji a kombinovat styly od country přes Mozarta až po Beatles.

Ladislav Hagara | Komentářů: 5
včera 16:00 | Pozvánky

Spolek OpenAlt zve příznivce otevřených řešení a přístupu na 163. brněnský sraz, který proběhne v pátek 26. dubna od 18:00 v indické restauraci Everest na adrese Veveří 61.

Ladislav Hagara | Komentářů: 5
včera 15:33 | IT novinky

Všem dívkám v ICT vše nejlepší k dnešnímu Mezinárodnímu dni dívek v ICT (Wikipedie, Girls in ICT Day, YouTube).

Ladislav Hagara | Komentářů: 8
včera 12:22 | Nová verze

Byla vydána verze 1.12 systému pro správu a verzování zdrojových kódů Apache Subversion (Wikipedie). Přehled novinek v poznámkách k vydání.

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

Mozilla zveřejnila každoroční Internet Health Report, který popisuje aktuální společenská témata související s využíváním Internetu. Tentokrát se dotýkají mj. etiky algoritmů strojového učení, cílené reklamy a „chytrých měst“.

Fluttershy, yay! | Komentářů: 2
včera 08:44 | Nová verze

Webová aplikace pro správu repozitářů v gitu Gitea vyšla v nové verzi 1.8.0. Nově poskytuje OAuth 2.0, umožňuje archivaci repozitářů, skrývání organizací jako interních či soukromých, zamykání konverzací a mnoho dílčích změn.

Fluttershy, yay! | Komentářů: 6
Používáte headset pro virtuální realitu?
 (1%)
 (3%)
 (2%)
 (18%)
 (1%)
 (75%)
Celkem 241 hlasů
 Komentářů: 12, poslední 18.4. 01:19
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. 10:52 ferda
Jak rekurzivně spočítat všechny položky v adresáři.
Přečteno: 424×
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. 11:12 ondrejd
Rozbalit Rozbalit vše Re: Jak rekurzivně spočítat všechny položky v adresáři.
6.2. 11:16 ferda
Rozbalit Rozbalit vše Re: Jak rekurzivně spočítat všechny položky v adresáři.
Moc děkuji.
6.2. 12:56 Andrej | skóre: 46 | blog: Republic of Mordor | Zürich
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. 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. 14:01 Aleš Kapica | skóre: 49 | 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. 14:43 .
Rozbalit Rozbalit vše Re: Jak rekurzivně spočítat všechny položky v adresáři.
Jinak zdravej?
6.2. 14:46 Aleš Kapica | skóre: 49 | 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. 21:07 Andrej | skóre: 46 | blog: Republic of Mordor | Zürich
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.