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:22 | IT novinky

    Společnost OpenAI, která stojí za chatovacím robotem s umělou inteligencí (AI) ChatGPT, získala od investorů 122 miliard USD (2,6 bilionu Kč). Hodnota společnosti tak dosáhla 852 miliard dolarů (více než 18 bilionů Kč). Nejnovější kolo investování se stalo největší, jaké zatím firma uskutečnila, a peníze mají posílit ambiciózní plány rozšíření výpočetní kapacity, datových center a nábor talentů.

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

    Nástroj k identifikaci občanů v on-line komunikaci s úřady byl dnes dopoledne zhruba dvě hodiny částečně nedostupný. Problém se objevil kolem 09:00 a podařilo se ho vyřešit kolem 11:00. Částečně nedostupná byla služba Národní identitní autority (NIA), problémy podle DIA (Digitální a informační agentura) ovlivňovaly přihlašování například i přes bankovní identitu. „Dostupnost NIA byla plně obnovena, přihlášení k digitálním službám

    … více »
    Ladislav Hagara | Komentářů: 0
    dnes 13:00 | IT novinky

    Eben Upton oznámil další zdražení počítačů Raspberry Pi kvůli růstu cen pamětí a představil Raspberry Pi 4 s 3 GB RAM za 83,75 dolarů.

    Ladislav Hagara | Komentářů: 0
    dnes 04:33 | Humor

    Anthropic patrně omylem zveřejnil celý zdrojový kód svého CLI nástroje Claude Code prostřednictvím přiloženého sourcemap souboru v npm balíčku. Únik odhalil doposud nijak nezveřejněné funkce jako je například režim v utajení, autonomní agent 'KAIROS', orchestrace multi‑agentů, režim snění nebo dokonce virtuální mazlíček Buddy. Zajímavostí je detekce naštvání uživatele pomocí obyčejného regexpu. Anthropic rychle odstranil sourcemap a vydal opravu, nicméně kopie kódu se již stihly na GitHubu rozšířit mezi prostým lidem.

    NUKE GAZA! 🎆 | Komentářů: 8
    včera 14:33 | Humor

    Copilot automaticky vkládal do pull requestů 'propagační tipy', reklamní text se na GitHubu objevil ve více než jedenácti tisících pull requestech. Po vlně kritiky byla tato funkce zablokována a produktový manažer Tim Rogers připustil, že umožnit Copilotovi upravovat cizí pull requesty bez vědomí autorů byla chyba.

    NUKE GAZA! 🎆 | Komentářů: 4
    včera 12:55 | Upozornění

    Je 31. března a tedy Světový den zálohování (World Backup Day). Co by se stalo, kdyby Vám právě teď odešel počítač, tablet nebo telefon, který používáte?

    Ladislav Hagara | Komentářů: 4
    včera 12:44 | Upozornění

    Digitální a informační agentura (DIA) přistupuje ke změně formátu důvěryhodného seznamu České republiky z verze TLv5 na verzi TLv6, která nastane 29. dubna 2026 v 00:00 (CET). Ke změně formátu důvěryhodných seznamů členských států (tzv. Trusted Lists) dochází na základě změn příslušné unijní legislativy. Důvěryhodné seznamy se používají v rámci informačních systémů a aplikací zejména pro účely ověřování platnosti elektronických

    … více »
    Ladislav Hagara | Komentářů: 2
    včera 05:00 | Nová verze

    Rspamd (Wikipedie), tj. open source systému pro filtrování nevyžádané pošty, byl vydán v nové major verzi 4.0.0. Přehled novinek v Changelogu.

    Ladislav Hagara | Komentářů: 1
    30.3. 23:11 | Nová verze

    SolveSpace (Wikipedie), tj. multiplatformní open source parametrický 2D/3D CAD, byl vydán v nové verzi 3.2. Přehled novinek v Changelogu na GitHubu. Vyzkoušet lze novou oficiální webovou verzi.

    Ladislav Hagara | Komentářů: 10
    30.3. 18:22 | Pozvánky

    Organizátoři Dne IPv6, tradiční akce věnované tématům spojeným s tímto protokolem, vyhlásili Call for Abstracts. Na webu konference mohou zájemci přihlašovat příspěvky o délce 20 nebo 40 minut či 10minutové lighting talky a to až do 30. dubna. Tvůrci programu uvítají návrhy přednášek z akademického i komerčního sektoru, které mohou být technického i netechnického zaměření. Den IPv6 se letos uskuteční 4. června a místem konání bude i

    … více »
    VSladek | Komentářů: 12
    Které desktopové prostředí na Linuxu používáte?
     (15%)
     (7%)
     (1%)
     (12%)
     (30%)
     (3%)
     (5%)
     (1%)
     (14%)
     (23%)
    Celkem 1201 hlasů
     Komentářů: 29, poslední včera 11:17
    Rozcestník

    Dotaz: Rekurzivne nahradenie/vymazanie znaku v 2. stlpci suboru

    25.1.2016 12:01 Ladislav
    Rekurzivne nahradenie/vymazanie znaku v 2. stlpci suboru
    Přečteno: 454×
    Dobry den, niesom velmi v konzole zbehly ale riesim nasledujuci problem. Mam textove subory v ktorych je rozny pocet stlpcov. Minimalny pocet je 2. Tieto subory su v roznych podadresaroch. Potrebujem aby sa v kazdom subore v 2. stlpci ak prvy znak je 0 tento znak vymazal. Moj pokus je takyto:
    #!/bin/bash
    
    for i in $(find . -name *.txt); do
      awk '{gsub("^0","",$2); print $1,$2}' $i
    done
    
    avsak tento skript vypise iba opravene stlpce ale nezapise zmeny do suboru. Viete ma nejako usmernit spravnym smerom ?

    Dakujem.

    Odpovědi

    25.1.2016 12:22 NN
    Rozbalit Rozbalit vše Re: Rekurzivne nahradenie/vymazanie znaku v 2. stlpci suboru
    #!/bin/bash
    
    for i in $(find . -name *.txt); do
        sed -ri 's/\ 0(.*)$/\ \1/g' $i
    done
    
    Urizne prvni nulu za mezerou z prava, asi by to slo i elegantneji. Doporucuji nejprve otestovat(bez -i).
    25.1.2016 12:33 Ladislav
    Rozbalit Rozbalit vše Re: Rekurzivne nahradenie/vymazanie znaku v 2. stlpci suboru
    Hmmm - no nevymaze to pociatocnu nulu z druheho stlpca :-( (skusal som bez -i)
    Jendа avatar 25.1.2016 18:13 Jendа | skóre: 78 | blog: Jenda | JO70FB
    Rozbalit Rozbalit vše Re: Rekurzivne nahradenie/vymazanie znaku v 2. stlpci suboru
    sed -r 's/^([^ ]+)( +)0(.*)$/\1\2\3/g'
    wamba avatar 25.1.2016 14:27 wamba | skóre: 38 | blog: wamba
    Rozbalit Rozbalit vše Re: Rekurzivne nahradenie/vymazanie znaku v 2. stlpci suboru
    čím jsou odděleny sloupce, mezery?

    třeba: find -name "*\.txt" |xargs perl -i -anE '$F[1] =~ s/^0//g;say "@F"'

    opět pro zkoušku lze vynechat -i
    This would have been so hard to fix when you don't know that there is in fact an easy fix.
    25.1.2016 14:43 Ladislav
    Rozbalit Rozbalit vše Re: Rekurzivne nahradenie/vymazanie znaku v 2. stlpci suboru
    Ano medzera. Tento skript funguje, akurat zmensuje medzery, co by asi vadit nemalo, ale to sa dozviem az ked budem tieto TXT subory importovat na dalsie spracovanie. Da sa aj bez toho zmensovania medzier ? Dakujem kazdopadne.
    wamba avatar 25.1.2016 15:32 wamba | skóre: 38 | blog: wamba
    Rozbalit Rozbalit vše Re: Rekurzivne nahradenie/vymazanie znaku v 2. stlpci suboru
    záleží jestli chcete ty mezery zachovat, pak třeba: find -name "*\.txt" |xargs perl -i -pE 's/^\s*\S+\s+\K0//;'.

    nebo jen zvětšit mezery: find -name "*\.txt" |xargs perl -i -anE '$"="\t";$F[1] =~ s/^0//g;say "@F"'
    This would have been so hard to fix when you don't know that there is in fact an easy fix.
    25.1.2016 18:22 Andrej | skóre: 51 | blog: Republic of Mordor
    Rozbalit Rozbalit vše Re: Rekurzivne nahradenie/vymazanie znaku v 2. stlpci suboru

    Tvůj pokus má jednu vadu: nezachovává sloupce následující po druhém sloupci.

    Tady je můj výstřel do tmy, který soubory už přímo edituje a zachovává všechny sloupce. Počítá s tabulátory jako oddělovači, ale klidně si tam lze dosadit místo \t mezery nebo skupiny znaků.

    find . -name '*.txt' -exec sed -ir \
      's/(^[\t]*[^\t]+[\t]+)0(.*$)/\1\2/' '{}' +
    
    Co když je v tom druhém sloupci pouze jedna samotná nula nebo více nul a nic nenulového za nimi? Pak by tam asi měla zůstat právě jedna nula, že ano. To bych udělal zhruba takto:
    find . -name '*.txt' -exec sed -ir \
      's/(^[\t]*[^\t]+[\t]+)0+(([^\t0]|0).*$)/\1\2/' '{}' +
    

    Tohle^^^ by mělo druhý sloupec nahradit takto:

    0 -> 0
    00 -> 0
    000 -> 0
    ...
    cosi -> cosi
    0cosi -> cosi
    00cosi -> cosi
    ...
    
    25.1.2016 18:25 Andrej | skóre: 51 | blog: Republic of Mordor
    Rozbalit Rozbalit vše Re: Rekurzivne nahradenie/vymazanie znaku v 2. stlpci suboru

    Aha. Teď v diskusi výše vidím, že oddělovače jsou mezery. Takže:

    find . -name '*.txt' -exec sed -ir \
      's/(^ *[^ ]+ +)0(.*$)/\1\2/' '{}' +
    find . -name '*.txt' -exec sed -ir \
      's/(^ *[^ ]+ +)0+(([^ 0]|0).*$)/\1\2/' '{}' +

    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.