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í
×
    včera 17:22 | Nová verze

    Raspberry Pi Connect, tj. oficiální služba Raspberry Pi pro vzdálený přístup k jednodeskovým počítačům Raspberry Pi z webového prohlížeče, byla vydána v nové verzi 2.5. Nejedná se už o beta verzi.

    Ladislav Hagara | Komentářů: 0
    včera 15:22 | Komunita

    Google zveřejnil seznam 1272 projektů (vývojářů) od 185 organizací přijatých do letošního, již jednadvacátého, Google Summer of Code. Plánovaným vylepšením v grafických a multimediálních aplikacích se věnuje článek na Libre Arts.

    Ladislav Hagara | Komentářů: 0
    8.5. 19:22 | Nová verze

    Byla vydána (𝕏) dubnová aktualizace aneb nová verze 1.100 editoru zdrojových kódů Visual Studio Code (Wikipedie). Přehled novinek i s náhledy a videi v poznámkách k vydání. Ve verzi 1.100 vyjde také VSCodium, tj. komunitní sestavení Visual Studia Code bez telemetrie a licenčních podmínek Microsoftu.

    Ladislav Hagara | Komentářů: 0
    8.5. 18:00 | Nová verze

    Open source platforma Home Assistant (Demo, GitHub, Wikipedie) pro monitorování a řízení inteligentní domácnosti byla vydána v nové verzi 2025.5.

    Ladislav Hagara | Komentářů: 0
    8.5. 01:22 | Nová verze Ladislav Hagara | Komentářů: 0
    8.5. 00:55 | Zajímavý projekt

    PyXL je koncept procesora, ktorý dokáže priamo spúštat Python kód bez nutnosti prekladu ci Micropythonu. Podľa testov autora je pri 100 MHz približne 30x rýchlejší pri riadeni GPIO nez Micropython na Pyboard taktovanej na 168 MHz.

    vlk | Komentářů: 0
    7.5. 19:44 | Nová verze

    Grafana (Wikipedie), tj. open source nástroj pro vizualizaci různých metrik a s ní související dotazování, upozorňování a lepší porozumění, byla vydána ve verzi 12.0. Přehled novinek v aktualizované dokumentaci.

    Ladislav Hagara | Komentářů: 0
    7.5. 17:33 | Nová verze

    Raspberry Pi OS, oficiální operační systém pro Raspberry Pi, byl vydán v nové verzi 2025-05-06. Přehled novinek v příspěvku na blogu Raspberry Pi a poznámkách k vydání. Pravděpodobně se jedná o poslední verzi postavenou na Debianu 12 Bookworm. Následující verze by již měla být postavena na Debianu 13 Trixie.

    Ladislav Hagara | Komentářů: 0
    7.5. 05:33 | Komunita

    Richard Stallman dnes v Liberci přednáší o svobodném softwaru a svobodě v digitální společnosti. Od 16:30 v aule budovy G na Technické univerzitě v Liberci. V anglickém jazyce s automaticky generovanými českými titulky. Vstup je zdarma i pro širokou veřejnost.

    Ladislav Hagara | Komentářů: 17
    7.5. 03:55 | Komunita

    sudo-rs, tj. sudo a su přepsáné do programovacího jazyka Rust, nahradí v Ubuntu 25.10 klasické sudo. V plánu je také přechod od klasických coreutils k uutils coreutils napsaných v Rustu.

    Ladislav Hagara | Komentářů: 0
    Jaký filesystém primárně používáte?
     (57%)
     (1%)
     (8%)
     (22%)
     (4%)
     (2%)
     (2%)
     (1%)
     (1%)
     (3%)
    Celkem 570 hlasů
     Komentářů: 26, poslední 8.5. 09:58
    Rozcestník
    Štítky: není přiřazen žádný štítek

    Dotaz: Pomůžete mi prosím se seřazením položek v array?

    22.2.2019 00:21 Veronika
    Pomůžete mi prosím se seřazením položek v array?
    Přečteno: 686×
    Ahoj pánové, jak můžu prosím jednoduše seřadit položky podle posledního čísla? Položky jsou uloženy v array?

    Tohle tam je teď.
    /foo/bar/1/3/10
    /foo/bar/1/3/11
    /foo/bar/1/3/18
    /foo/bar/1/3/2
    /foo/bar/1/3/24
    /foo/bar/1/3/25
    /foo/bar/1/3/5
    /foo/bar/1/3/6
    /foo/bar/1/3/8
    /foo/bar/1/3/9
    
    Tohle potřebuji
    /foo/bar/1/3/2
    /foo/bar/1/3/5
    /foo/bar/1/3/6
    /foo/bar/1/3/8
    /foo/bar/1/3/9
    /foo/bar/1/3/10
    /foo/bar/1/3/11
    /foo/bar/1/3/18
    /foo/bar/1/3/24
    /foo/bar/1/3/25
    
    Zkoušela jsem hledat, opravdu, nenašla jsem ale lautr nic :( Děkuji, V.

    Řešení dotazu:


    Odpovědi

    Aleš Janda avatar 22.2.2019 08:03 Aleš Janda | skóre: 23 | blog: kýblův blog | Praha
    Rozbalit Rozbalit vše Re: Pomůžete mi prosím se seřazením položek v array?
    Pokud je prefix furt stejný, bude fungovat

    sort -n soubor
    Jendа avatar 22.2.2019 12:56 Jendа | skóre: 78 | blog: Jenda | JO70FB
    Rozbalit Rozbalit vše Re: Pomůžete mi prosím se seřazením položek v array?
    Už jsem chtěl napsat že sort má parametr -k, ale array? Buď používá pole v Bashi, nebo je to nějaký jiný jazyk a nevíme který… Pro ten jiný jazyk pak platí univerzální rada: pohledej, jak se jeho sortu předává vlastní komparační funkce.
    25.2.2019 00:15 Veronika
    Rozbalit Rozbalit vše Re: Pomůžete mi prosím se seřazením položek v array?
    Jedná se o shell/bash
    25.2.2019 01:34 debian+
    Rozbalit Rozbalit vše Re: Pomůžete mi prosím se seřazením položek v array?
    https://stackoverflow.com/a/11789688
    25.2.2019 15:23 Andrej | skóre: 51 | blog: Republic of Mordor
    Rozbalit Rozbalit vše Re: Pomůžete mi prosím se seřazením položek v array?
    Zkoušela jsem hledat, opravdu, nenašla jsem ale lautr nic :( Děkuji, V.

    Domácí úkol nemáš hledat, máš ho vyřešit. Je to cvičení na obecné dovednosti kolem UNIXu a na základy programování, čtení manuálových stránek atd. Pokud bude někdo řešit úkoly za tebe, u zkoušky nebo zápočtového testu přijdou krušné chvíle.

    Nespecifikuješ, jestli to musí být efektivní. Předpokládám, že ne. Tak prosím, tady je výstavní kvadratický hnus:

    sort_by_number_after_last_slash() {
      local -i -r INT_MAX=9223372036854775807  # 2^63 - 1
      local -n -r input_reference="$1"
      local -n output_reference="$2"
      local -a input=("${input_reference[@]}")
      local -i index sorting_key minimum minimum_index
    
      for index in "${!output_reference[@]}"; do
        unset output_reference[index]
      done
      while ((${#input[@]} > 0)); do
        minimum=INT_MAX
        for index in "${!input[@]}"; do
          sorting_key="${input[index]##*/}"
          if ((sorting_key < minimum)); then
            minimum=sorting_key
            minimum_index=index
          fi
        done
        output_reference+=("${input[minimum_index]}")
        unset input[minimum_index]
      done
    }
    

    A tady je ukázka, jak se to používá (a drobný test, jestli to funguje, jak má):

    declare -a unsorted_array=(
      '/foo/bar/1/3/10'
      '/foo/bar/1/3/11'
      '/foo/bar/1/3/18'
      '/foo/bar/1/3/2'
      '/foo/bar/1/3/24'
      '/foo/bar/1/3/25'
      '/foo/bar/1/3/5'
      '/foo/bar/1/3/6'
      '/foo/bar/1/3/8'
      '/foo/bar/1/3/9'
    )
    declare -a sorted_array=('nonsense, should disappear')
    
    ###########################################################
    sort_by_number_after_last_slash unsorted_array sorted_array
    ###########################################################
    
    echo "Original array (must be unchanged):"
    for item in "${unsorted_array[@]}"; do
      echo "${item}"
    done
    echo "Sorted and unsorted array size (must be equal):"
    echo "${#sorted_array[@]}" "${#unsorted_array[@]}"
    echo "Sorted array (must be ... sorted):"
    for item in "${sorted_array[@]}"; do
      echo "${item}"
    done
    
    26.2.2019 01:42 Andrej | skóre: 51 | blog: Republic of Mordor
    Rozbalit Rozbalit vše Re: Pomůžete mi prosím se seřazením položek v array?

    :-D :-D :-D
    :-D :-D :-D
    :-D :-D :-D

    Zapomněl jsem, že řídká pole se iterují v pořadí podle indexů. Takže i tohle by mohlo fungovat. Lepší řídká pole než řídká stolice. (Jenom to nesnese záporná čísla v těch názvech souborů, ale co už.)

    sort_by_number_after_last_slash() {
      local -n -r input_reference="$1"
      local -n output_reference="$2"
      local -a input_map
      local item
    
      for item in "${input_reference[@]}"; do
        input_map["${item##*/}"]="${item}"
      done
      output_reference=()
      for item in "${input_map[@]}"; do
        output_reference+=("${item}")
      done
    }
    
    26.2.2019 18:25 Veronika
    Rozbalit Rozbalit vše Re: Pomůžete mi prosím se seřazením položek v array?
    Díky. Ještě, že umím vařit :-(
    26.2.2019 01:59 Andrej | skóre: 51 | blog: Republic of Mordor
    Rozbalit Rozbalit vše Re: Pomůžete mi prosím se seřazením položek v array?

    Ještě bych dodal, jen tak z prdele, co s tím, kdyby to muselo být efektivní a kdyby to náhodou nesmělo využívat řídká pole v Bashi. #firstworldproblems #becausewecan

    Napřed si vyrobíme mergesort na integery:

    mergesort() {
      local -n -r input_reference="$1"
      local -n output_reference="$2"
      local -r -i size="${#input_reference[@]}"
      local -a -i merge runs indices
      local -i index previous merged_idx \
               run_a_idx run_a_stop \
               run_b_idx run_b_stop
    
      output_reference=("${input_reference[@]}")
      if ((size == 0)); then return; fi
    
      previous=output_reference[0]
      runs=(0)
      for ((index = 0;;)) do
        for ((++index;; ++index)); do
          if ((index >= size)); then break 2; fi
          if ((output_reference[index] < previous)); then break; fi
          previous=output_reference[index]
        done
        previous=output_reference[index]
        runs+=(index)
      done
      runs+=(size)
    
      while (("${#runs[@]}" > 2)); do
        indices=("${!runs[@]}")
        merge=("${output_reference[@]}")
        for ((index = 0; index < "${#indices[@]}" - 2; index += 2)); do
          merged_idx=runs[indices[index]]
          run_a_idx=merged_idx
          previous=indices[$((index + 1))]
          run_a_stop=runs[previous]
          run_b_idx=runs[previous]
          run_b_stop=runs[indices[$((index + 2))]]
          unset runs[previous]
          while ((run_a_idx < run_a_stop && run_b_idx < run_b_stop)); do
            if ((merge[run_a_idx] < merge[run_b_idx])); then
              output_reference[merged_idx++]=merge[run_a_idx++]
            else
              output_reference[merged_idx++]=merge[run_b_idx++]
            fi
          done
          while ((run_a_idx < run_a_stop)); do
            output_reference[merged_idx++]=merge[run_a_idx++]
          done
          while ((run_b_idx < run_b_stop)); do
            output_reference[merged_idx++]=merge[run_b_idx++]
          done
        done
      done
    }
    
    A pak na to klidně napasujeme třídění těch cest k souborům. Míle a míle se táhnou těch cest. Tady už se ale řídká pole používají, ježto se mi to nechtělo řešit jinak, a v tom je ošklivost: Výraz "${!input_map[@]}" dá ty indexy už setříděné, takže následující mergesort krok je úplně k hovnu. Ale to nevadí, když máme ten mergesort tak úžasně efektivní, on se s tím moc párat nebude (1 běh a konec).
    sort_by_number_after_last_slash() {
      local -n -r input_reference="$1"
      local -n output_reference="$2"
      local -a -i input output
      local -a input_map
      local item
    
      for item in "${input_reference[@]}"; do
        input_map["${item##*/}"]="${item}"
      done
      input=("${!input_map[@]}")
      mergesort input output  # na hovno
      echo "${input[@]}"
      echo "${output[@]}"
      output_reference=()
      for item in "${output[@]}"; do
        output_reference+=("${input_map[item]}")
      done
    }
    
    Byť je tohle všechno na prd, jako zajímavá ukázka na hraní s Bashem to může být dobré (ten mergesort přinejmenším).
    declare -a -i unsorted=(RANDOM RANDOM RANDOM RANDOM RANDOM)
    declare -a -i sorted
    mergesort unsorted sorted
    echo "${unsorted[@]}"
    echo "${sorted[@]}"
    
    27.2.2019 09:50 Milan Uhrák | skóre: 31 | blog: milan_at_ABC
    Rozbalit Rozbalit vše Re: Pomůžete mi prosím se seřazením položek v array?
    Zdravím Andreji, je vidět, že máte bash v malíčku. Kdyby jste měl problém se stravou, Veronika něco naznačovala .. :-D

    Snad je opravdová a má to očekávané pohlaví, a ne některé z 64 nebo kolika schválených kajsi západně od našich hranic .. M.

    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.