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 05:11 | Komunita

    Byly zpracovány a na YouTube zveřejněny videozáznamy jednotlivých přednášek z letošního Installfestu.

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

    Během akce Arduino Days 2026 byl publikován Arduino Open Source Report 2025 (pdf) a oznámeno 7 nových produktů kompatibilních s deskou UNO Q (Arduino USB-C Power Supply, USB-C Cable, USB-C Hub, UNO Media Carrier, UNO Breakout Carrier, Bug Hopper, Modulino LED Matrix).

    Ladislav Hagara | Komentářů: 0
    včera 20:22 | IT novinky

    Google v pátek spustil v Česku Vyhledávání Live. Tato novinka umožňuje lidem vést plynulou konverzaci s vyhledávačem v češtině. A to prostřednictvím hlasu, nebo prostřednictvím toho, na co ukážou svým fotoaparátem či kamerou v mobilu. Rozšíření této multimodální funkce je možné díky nasazení Gemini 3.1 Flash Live, nového hlasového a audio modelu, který je od základu vícejazyčný, takže umožňuje lidem po celém světě mluvit na vyhledávač přirozeně a v jazyce, který je jim nejbližší.

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

    Jsongrep je open-source nástroj, který efektivně prohledává JSON dokumenty (editovat je neumí). Kompiluje regulérní jazyk dotazu do podoby deterministického konečného automatu (DFA), díky čemuž prochází strom JSON dokumentu pouze jednou a je v tom tedy rychlejší než jiné nástroje jako jsou například jq, JMESPath nebo jql. Jsongrep je napsaný v programovacím jazyce Rust, zdrojový kód je dostupný na GitHubu.

    NUKE GAZA! 🎆 | Komentářů: 3
    28.3. 05:55 | Komunita

    O víkendu probíhá v Praze na Karlově náměstí 13 konference Installfest 2026. Na programu je celá řada zajímavých přednášek a workshopů. Vstup na konferenci je zcela zdarma, bez nutnosti registrace. Přednášky lze sledovat i online na YouTube.

    Ladislav Hagara | Komentářů: 10
    28.3. 05:22 | Komunita

    Mozilla a společnost Mila oznámily strategické partnerství za účelem rozvoje open source a suverénní AI. Cílem je ukázat, že open source AI může konkurovat uzavřeným systémům. Obě organizace chtějí posílit technologickou suverenitu a snížit závislost na hrstce velkých technologických firem.

    Ladislav Hagara | Komentářů: 4
    28.3. 04:00 | Humor

    Adam Rice předvedl, že pomocí DNS lze distribuovat a spustit kompletní hru DOOM. Rozdělil WAD soubory a binárky do téměř 2000 DNS záznamů v Cloudflare zóně (jeden TXT záznam v DNS může nést okolo 2000 znaků textu). Ty pak stáhl PowerShellem, dekomprimoval a spustil přímo v paměti počítače bez nutnosti zápisu na disk, což prakticky dokazuje, že DNS může sloužit jako distribuované úložiště dat a možný kanál pro načítání kódu. Repozitář projektu je na GitHubu.

    NUKE GAZA! 🎆 | Komentářů: 7
    27.3. 13:00 | Komunita

    Dnes a zítra probíhají Arduino Days 2026. Na programu je řada zajímavých přednášek. Sledovat je lze od 17:00 na YouTube. Zúčastnit se lze i lokálních akcí. Dnes v Poličce v městské knihovně a zítra v Praze na Matfyzu.

    Ladislav Hagara | Komentářů: 9
    27.3. 12:11 | Nová verze

    Byla vydána beta verze Ubuntu 26.04 LTS s kódovým názvem Resolute Raccoon. Přehled novinek v poznámkách k vydání. Dle plánu by Ubuntu 26.04 LTS mělo vyjít 23. dubna 2026.

    Ladislav Hagara | Komentářů: 2
    27.3. 02:22 | Komunita Ladislav Hagara | Komentářů: 12
    Které desktopové prostředí na Linuxu používáte?
     (15%)
     (7%)
     (1%)
     (12%)
     (30%)
     (3%)
     (5%)
     (2%)
     (14%)
     (24%)
    Celkem 1183 hlasů
     Komentářů: 27, poslední 17.3. 19:26
    Rozcestník

    0

    2.12.2021 01:06 | Linux | poslední úprava: 23.5.2025 12:47

    0        

    Hodnocení: 100 %

            špatnédobré        

    Tiskni Sdílej: Linkuj Jaggni to Vybrali.sme.sk Google Del.icio.us Facebook

    Komentáře

    Vložit další komentář

    2.12.2021 01:21 Miriam | blog: RychlovarnaKonvice
    Rozbalit Rozbalit vše Re: Výpis stejných souborů (Perl vs Ruby)
    Perl je hlavně mrtvý jazyk. Zdar Max
    2.12.2021 01:32 sad
    Rozbalit Rozbalit vše Re: Výpis stejných souborů (Perl vs Ruby)
    Ruby už má zřejmě to nejlepší také za sebou...
    2.12.2021 09:12 ja osobne
    Rozbalit Rozbalit vše Re: Výpis stejných souborů (Perl vs Ruby)
    Teraz letí jedine JavaScript a RUST !!!
    2.12.2021 02:10 tttt
    Rozbalit Rozbalit vše Re: Výpis stejných souborů (Perl vs Ruby)
    require 'pathname'
    
    @dir = ARGV[0] || __dir__
    
    Pathname.new(@dir).children.select(&:file?)
      .group_by { |path| File.size(path) }
      .tap { |h| h.delete(1) }
      .each do |k, v|
      puts "Found #{v.length} files with size #{k} bytes:"
      puts v
      puts
    end
    2.12.2021 02:22 tttt
    Rozbalit Rozbalit vše Re: Výpis stejných souborů (Perl vs Ruby)
    7. řádek zahazuje malé soubory, koukám, že to má zahazovat unikátní. Mělo to tedy být:
    .select { |_, v| v.length > 1 }
    2.12.2021 02:34 sad
    Rozbalit Rozbalit vše Re: Výpis stejných souborů (Perl vs Ruby)
    Hezký a elegantní způsob. Dík.
    2.12.2021 08:38 luky
    Rozbalit Rozbalit vše Re: Výpis stejných souborů (Perl vs Ruby)
    my %sizes; $, = "\n";
    unshift @{$sizes{-s $_}}, $_ foreach grep -f $_, glob "* .*";
    foreach (keys %sizes) {
            next unless $#{$sizes{$_}};
            print 'Found ' . ($#{$sizes{$_}} + 1) . " files with size $_ bytes:\n";
            print @{$sizes{$_}}, "\n";
    }
    
    2.12.2021 08:41 luky
    Rozbalit Rozbalit vše Re: Výpis stejných souborů (Perl vs Ruby)
    Vypis by sel na jeden radek pres grep taky, ale uz je to pak necitelne.
    2.12.2021 12:31 z_sk | skóre: 34 | blog: analyzy
    Rozbalit Rozbalit vše Re: Výpis stejných souborů (Perl vs Ruby)
    <?php
    
    // nacita zoznam suborov
    $list=scandir(".");
    
    // zisti velkosti
    $statistic=array();
    foreach($list as $name)
    	if(is_file($name))
    	{
    		$size=filesize($name);
    		if(isset($statistic[$size]))
    			array_push($statistic[$size], "$name");
    		else
    			$statistic[$size]=array("$name");
    	}
    
    // vypise
    foreach($statistic as $size => $items)
    {
    	$count=count($items);
    	if($count < 2)
    		continue;
    	echo "Size: ${size} B, count: $count\n";
    	echo implode("\n", $items)."\n";
    }
    
    
    debian.plus@protonmail.com
    2.12.2021 17:22 Odin1918 | skóre: 6 | blog: Valhalla
    Rozbalit Rozbalit vše Re: Výpis stejných souborů (Perl vs Ruby)
    K cemu je seskupeni souboru podle velikosti? Jiste, pravdepodobnost duplicity nejaka je, ale nebylo by lepsi vypocitat alespon md5ku a s tou operovat?
    2.12.2021 14:22 Tomáš
    Rozbalit Rozbalit vše Re: Výpis stejných souborů (Perl vs Ruby)
    A nechtěl by ses kromě velikosti podívat i na obsah souboru? To, že jsou soubory stejně dlouhé, většinou neznamená, že musejí být stejné.

    Většinou se počítá nějaký hash nebo checksum a pak se porovnávají mezi sebou.
    2.12.2021 15:01 sad
    Rozbalit Rozbalit vše Re: Výpis stejných souborů (Perl vs Ruby)
    require 'digest/md5'
    
    digest = Digest::MD5.hexdigest(File.read(f))
    
    Heron avatar 3.12.2021 19:55 Heron | skóre: 53 | blog: root_at_heron | Olomouc
    Rozbalit Rozbalit vše Re: Výpis stejných souborů (Perl vs Ruby)
    Viz poznámka níže. Nepoužívejte md5. Jsou k disposici různé soubory se stejnou md5 hash. Úprava pro SHA512 je triviální.
    NUKE GAZA! 🎆 avatar 2.12.2021 22:47 NUKE GAZA! 🎆 | skóre: 42 | blog: Grétin blogísek | 🇮🇱==❤️ , 🇵🇸==💩 , 🇪🇺==☭
    Rozbalit Rozbalit vše Re: Výpis stejných souborů (Perl vs Ruby)

    supr skripty :D ;D

    teda já jako perlu a ruby vubec nerozumim ale vidim žeto neni koronarýma tak jakoby lajkuju :D :D ;D ;D

    3.12.2021 00:05 kvr
    Rozbalit Rozbalit vše Re: Výpis stejných souborů (Perl vs Ruby)
    perl -e 'use File::Slurp; $x{$_}++ foreach (map({ -s $_ } read_dir("."))); while (my ($s, $c) = each(%x)) { print("size=$s count=$c\n") if ($c > 1); }'
    3.12.2021 00:32 kvr
    Rozbalit Rozbalit vše Re: Výpis stejných souborů (Perl vs Ruby)
    A "nepopulární" Java:

    Arrays.stream(new File(".").listFiles()) .map(file -> file.length()) .collect(Collectors.groupingBy(Function.identity(), Collectors.counting())) .forEach((s, c) -> if (c > 1) System.out.printf("size=%s count=%c\n", s, c));

    Kratší než oba původní příklady (i když ty by šly taky zkrátit, viz výše) a přesto IMHO čitelnější. Ta čitelnost se pak objeví v případě větší komplexity, teď je to přece jen dost primitivní podle jednoho klíče.
    3.12.2021 09:29 srbt | skóre: 6
    Rozbalit Rozbalit vše Python
    Zdá se mi, že to sem ještě nikdo nenapsal v tom zmiňovaném pythonu, tak jsem si dovolil...
    #!/usr/bin/env python3
    
    from pathlib import Path
    from itertools import groupby
    
    files = sorted((file.stat().st_size, file) for file in Path('.').iterdir() if file.is_file())
    
    groups = (same_files for size, group in groupby(files, lambda x: x[0]) if len(same_files := list(group)) > 1)
    
    for group in groups:
        print('Found {count} files with size {size} bytes:\n{files}\n'.format(
            count=len(group),
            size=group[0][0],
            files='\n'.join(file[1].name for file in group)
        ))
    
    Omlouvám se za použití operátoru :=.
    3.12.2021 10:02 srbt | skóre: 6
    Rozbalit Rozbalit vše Bash
    No a ještě v bashi a gnu tools:
    #!/usr/bin/env bash
    
    files="$(find . -type f -printf '%s %f\n' | sort -n)"
    sizes="$(cut -f 1 -d ' ' <<< "$files" | uniq --repeated)"
    
    for size in $sizes; do
      count="$(grep -c "^$size " <<< "$files")"
      names="$(grep "^$size " <<< "$files" | cut -f 2 -d ' ')"
      printf 'Found %s files with size %s bytes:\n%s\n\n' "$count" "$size" "$names"
    done
    
    Gilhad avatar 3.12.2021 11:09 Gilhad | skóre: 20 | blog: gilhadoviny
    Rozbalit Rozbalit vše Re: Výpis stejných souborů (Perl vs Ruby)
    Pro hledani duplicitnich souboru (teda nejen stejne dlouhych) pouzivam neco jako

    find -type f -exec md5sum {} \; | sort |uniq --all-repeated=separate -w32

    (teda normalne ty md5sum mam nekde ulozene a pracuju s nima opakovane, takze to jsou bezne prikazy 2, jeden vytvori seznam hashu souboru, druhy hleda duplicity)
    Heron avatar 3.12.2021 19:50 Heron | skóre: 53 | blog: root_at_heron | Olomouc
    Rozbalit Rozbalit vše Re: Výpis stejných souborů (Perl vs Ruby)
    Nepoužívej md5. Je prolomená, je slabá, jsou k disposici různé souboru se stejným md5 hashem. Uprav si ten skript pro sha512sum. Jsou to dvě změny.
    4.12.2021 12:33 Want
    Rozbalit Rozbalit vše Re: Výpis stejných souborů (Perl vs Ruby)
    A proč zdlouhavě počítat kontrolní součet? Není jednodušší o souborů o shodné délce nejprve binárně porovnat začátek a konec, a teprve po této shodě ověřit kontrolní součet, případně použít metodu, která by vykázala procentuální shodu obsahu?
    Heron avatar 4.12.2021 14:35 Heron | skóre: 53 | blog: root_at_heron | Olomouc
    Rozbalit Rozbalit vše Re: Výpis stejných souborů (Perl vs Ruby)
    Optimalizacím se věnuje komentář od Ploštěnky. Mým cílem bylo upozornit na již dávno překonanou funkci md5.

    Navíc Gilhad píše, že si ty hashe ještě někam ukládá, takže jeho cílem nejspíše není jen hledat stejné soubory (to by nám musel sdělit on). Proto rychlá úprava jeho skriptu na sha512sum je více než dostatečná.

    Já si například pravidelně ukládám shasumy všech souborů na datovém úložišti nikoliv pro hledání duplicit, ale proto, abych věděl, jestli se ty soubory mění nebo ne. V minulosti se mi stávalo, že video, které šlo bez problémů přehrát najednou nešlo. Nevím, jestli se ten soubor poškodil na disku a nebo jsem jen začal používat jiný přehrávač, který nebyl tolerantní k chybám. Právě proto jsem začal dělat checksumy, abych tohle případně zjistil. Pravděpodobnější ovšem je, že ten soubor byl poškozen od počátku - tako jsem měl mp3, které winamp dokázal přehrát bez problémů, ale jiné přehrávače - po mém přechodu na linux - hlásily poškozený soubor. I dneska se stane, že je nějaký soubor vadný a proto důležitá videa nechám protáhnout přes ffmpeg, který to jednak detekuje a taky někdy umí opravit (pokud je to jen chyba v multiplexoru).

    Navíc mám díky tomu i historii souborů na disku a jsem schopen dohledat existenci souboru, který jsem já blbec smazal, a teď bych jej potřeboval - sice mi to data nevrátí, ale alespoň vím, kdy k tomu došlo a to mi může pomoci při pátrání.
    6.12.2021 07:56 Tomáš | skóre: 31 | blog: Tomik
    Rozbalit Rozbalit vše Re: Výpis stejných souborů (Perl vs Ruby)
    A není na tohle lepší nějaký verzovací systém? Ten ty checksumy dělá implicitně.
    9.12.2021 19:17 marbu | skóre: 31 | blog: hromada | Brno
    Rozbalit Rozbalit vše Re: Výpis stejných souborů (Perl vs Ruby)
    Na nějak omezenou množinu dat možná, ale tady Heron mluví "všech souborech na datovém úložišti", a v takovém případě bych řekl že spíš ne. Nechtěl bych verzovat něco jako celý /home ...
    There is no point in being so cool in a cold world.
    9.12.2021 19:27 marbu | skóre: 31 | blog: hromada | Brno
    Rozbalit Rozbalit vše Re: Výpis stejných souborů (Perl vs Ruby)
    Já si například pravidelně ukládám shasumy všech souborů na datovém úložišti nikoliv pro hledání duplicit, ale proto, abych věděl, jestli se ty soubory mění nebo ne.
    Tohle dělám taky, akorát pouze při zálohování celého /home oddílu. Udělám snapshot kvůli konzistenci, v něm nechám spočítat checksum všeho a pak spustím zálohu. Ten checksum soubor mám pak jak lokálně tak u té zálohy, takže v případě poškozeného binárního souboru co se normálně moc nemění jsem schopen rychle dohledat v které záloze mám předchozí verzi. Ale dělám to primárně kvůli kontrole konzistence zálohy a obnovených dat.
    There is no point in being so cool in a cold world.
    Gilhad avatar 17.12.2021 14:41 Gilhad | skóre: 20 | blog: gilhadoviny
    Rozbalit Rozbalit vše Re: Výpis stejných souborů (Perl vs Ruby)
    Cílem je 1) hledání duplicitních souborů 2) ověřování zda se soubor nezměnil

    Úprava na jiný součet je poněkud nepraktická, protože to je součástí systému, který jsem napsal kdysí, asi tak mezi 2000 a 2002, pro mou tehdejší 486 za účelem ukládání na CDčka a zase vytahování z nich, a v té době jsem tam narval podstatnou část souborů.

    Problém je, že některá CD se časem stávala méně a méně čitelná, cena CD/DVD klesala a soubory jsem nejen přejmenovával (z různých kódování češtin, ale i z různých stylů popisu), ale i přesouval mezi adresáři a do toho se mi motaly starší verze (nepřejmenované) ale také verze novější, které přišly odjinud a jmenovaly se klidně jako verze starší, nebo naprosto jinak, protože si to někdo upravil podle svých konvencí.

    A samozřejmě klasika zálohy záloh záloh ... a stále používané verze na disku spadající jak do tématických záloh podle smyslu, tak do záloh náhodných, např. celého počítače.

    Takže v tom časem vzniknul pěkný bordel a bylo ho potřeba nějak rozmotat, nebo to na rozmotání aspoň připravit.

    Takže náhoda, že by dva soubory byly různé, ale došlo ke kolizi MD5, ale jejich název a umístění dávalo podobný smysl bylo celkem malé. Navíc jsem měl (ale jinde) i uložené délky a nějaké poznámky o formátu, pokud se rozpoznal (hudba, fotky, filmy, ...) a nečekal jsem, že by na tohle někdo cíleně zaútočil, protože to nedávalo smysl. Na druhou stranu jsem měl po různých adresářích mraky souborů typu SAVEGAME.001 a README.TXT, které byly povětšinou různé a záleželo na jejich umístění v adresářové struktuře, ke které gamese to asi tak patří ...

    Takže se mi to nechce předělávat, dokud to kompletně nezkonzoliduju na diskovém poli, duplicity (a balast) nevyházím a naopak nezjistím, co za léta došlo úhony, či ztráty. Což je projekt na léta, protože to má nízkou prioritu a jde o tisíce CD a stovky DVD ... Až budu jednou s výsledkem (relativné) spokojen, tak to předělám na optimalizaci pro disková pole a přegeneruju celý systém.

    Ale teď se mi hodí držet kompatibilitu se starou verzí a nové věci mít zároveň v GITu (ostatně teď předělávám i poněkud živelně vzniklou strukturu repozitářů na něco systematičtějšího a vhodnějšího pro současný styl práce)
    NUKE GAZA! 🎆 avatar 5.12.2021 18:45 NUKE GAZA! 🎆 | skóre: 42 | blog: Grétin blogísek | 🇮🇱==❤️ , 🇵🇸==💩 , 🇪🇺==☭
    Rozbalit Rozbalit vše Re: Výpis stejných souborů (Perl vs Ruby)

    když jakoby dělá jenom hledání duplicitních souborů někde  u sebe na disku tak vodolnost toho hashe neni zese jako moc důležitá ne?? :O :O

    joa neni md5 taky trošičku rychlejší/lacinější než sha512????? :O ;D

    Heron avatar 5.12.2021 21:02 Heron | skóre: 53 | blog: root_at_heron | Olomouc
    Rozbalit Rozbalit vše Re: Výpis stejných souborů (Perl vs Ruby)
    No když si někdo píše program, tak je celkem vhodné je napsat tak, aby byl správný z hlediska aktuálního poznání. To, že existují soubory s různým obsahem a stejnou md5 hash se ví, já mám takové soubory na disku a takto napsaný program by to vyhodnotil špatně. Proto je vhodné použít takovou hash fci, u které kolize ještě známé nejsou. hash funkce je modulární a měla by jít snadno vyměnit. Pro kontinuitu dat, pokud je potřeba, je vhodné použít několik funkcí současně a ukládat všechny hashe.
    joa neni md5 taky trošičku rychlejší/lacinější než sha512
    Netuším a je to jedno, stejně se čeká na storage, spočítat to je rychlejší, než číst z disku. Pokud má dotyčný data v 1TB ramdisku, tak to nemusí platit, ale v tom případě zřejmě bude mít něco jako EPIC a tak si to snadno může paralelizovat.

    Jinak pokud někomu vadí zrovna sha512, tak existují jiné, neprolomené a velmi rychlé funkce (třeba rodina sha3 - kde byla rychlost z jedním z požadavků soutěže).
    NUKE GAZA! 🎆 avatar 7.12.2021 21:18 NUKE GAZA! 🎆 | skóre: 42 | blog: Grétin blogísek | 🇮🇱==❤️ , 🇵🇸==💩 , 🇪🇺==☭
    Rozbalit Rozbalit vše Re: Výpis stejných souborů (Perl vs Ruby)
    3.12.2021 19:26 sad
    Rozbalit Rozbalit vše Re: Výpis stejných souborů (Perl vs Ruby)
    Ale nikde nevidím Rust. Zřejmě by v Rustu takový prográmek ani napsat nešel...
    3.12.2021 21:04 plostenka | blog: plstnk
    Rozbalit Rozbalit vše Re: Výpis stejných souborů (Perl vs Ruby)
    Jako petiminutovka dobre, ale kde je nejaka optimalizace?

    Pokud maji soubory unikatni velikost, nejsou stejne (netreba draze pocitat hash)
    Pokud maji soubory unikatni prvni 1kB, nejsou stejne (netreba draze pocitat hash) ...

    Ve vysledku pouzivam rdfind: find . -type f -size +100M -print0 | xargs -0 rdfind -ignoreempty true -checksum sha1 -makehardlinks true -outputname ./rdfind100M_results.txt -dryrun false > ./rdfind100_stdout.txt 2>&1

    Založit nové vláknoNahoru

    ISSN 1214-1267   www.czech-server.cz
    © 1999-2015 Nitemedia s. r. o. Všechna práva vyhrazena.