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 »Euro-Office (Wikipedie) je evropský fork open source kancelářského balíku OnlyOffice. Za forkem stojí koalice firem IONOS, Nextcloud, Eurostack, XWiki, OpenProject, Soverin, Abilian a BTactic. Cílem je zajistit digitální suverenitu Evropy a snížit závislost na neevropských platformách. Projekt vznikl mimo jiné v reakci na nedávné uzavření cloudové služby OnlyOffice. OnlyOffice obviňuje Euro-Office z porušení licenčních podmínek. Na možné problémy upozorňuje i Collabora Online. Jednostranná změna licence není v pořádku.
Byly zpracovány a na YouTube zveřejněny videozáznamy jednotlivých přednášek z letošního Installfestu.
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).
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žší.
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.
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.
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.
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.
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.
Zdravím všechny,
potřeboval bych pomoci, jak nahradit příkaz cut -c4- pomocí sedu. Našel jsem si toto
cut -c 10 = sed 's/\(.\)\{10\}.*/\1/'
Díky za nápady.
Řešení dotazu:
$ echo 1234567890 |cut -c4-
4567890
$ echo 1234567890 |sed 's/\(.\{3\}\)\(.*\)/\2/'
4567890
Řetězec se rozdělí na dvě části: \(.\{3\}\) - první tři znaky \(.*\) - zbytek (od čtvrtého znaku až na konec)\2.
$ echo 1234567890 | sed "s/.\{3\}//"
4567890
(nebo samozřejmě pro -c4- sed "s/...//"
).
Zdravim,
aky je zmysel tvojho pocinania, myslim vymeny cut za sed ? Cisto zo zaujimavosti sa pytam a z rovnakeho zakladu som odskusal cut, sed a bash v nasledujucom skripte:
#! /bin/bash
VAR='abcdefgh'
CUT_FUNCTION()
{
local INDEX
while [[ ${INDEX} -lt 1000 ]]
do
echo "${VAR}" | cut -c4- > /dev/null
let INDEX++
done
}
SED_FUNCTION()
{
local INDEX
while [[ ${INDEX} -lt 1000 ]]
do
echo "${VAR}" | sed 's/.\{3\}//' > /dev/null
let INDEX++
done
}
BASH_BUILTIN_FUNCTION()
{
local INDEX
while [[ ${INDEX} -lt 1000 ]]
do
echo "${VAR:3}" > /dev/null
let INDEX++
done
}
time CUT_FUNCTION
echo '-----------------------------------------'
time SED_FUNCTION
echo '-----------------------------------------'
time BASH_BUILTIN_FUNCTION
echo '-----------------------------------------'
A vystup skriptu je :
real 0m1.524s user 0m0.824s sys 0m0.764s ----------------------------------------- real 0m1.630s user 0m3.224s sys 0m1.104s ----------------------------------------- real 0m0.055s user 0m0.056s sys 0m0.000s -----------------------------------------
Niekolkokrat som to spustil a vzdy bol sed najpomalsi. A pokial mozes pouzit bash, tak potom je zrejme, co je pouzit najvhodnejsie a najrychlejsie. Ale mozno mas specificku situaciu, kedy to musi byt sed.
Kazdopadne to ber len ako zaujimavost, ak vobec. Nemal som co na robote, tak to takto vyzera potom. :)
cut ... soubor.txt, sed ... soubor.txt, while read; echo ...; done <souboru.txt).
Tak aby sme boli ferovy, tak som to zopakoval:
#! /bin/bash
SUBOR=subor.txt
CUT_FUNCTION()
{
cut -c4- "${SUBOR}" > /dev/null
}
SED_FUNCTION()
{
sed 's/.\{3\}//' "${SUBOR}" > /dev/null
}
BASH_BUILTIN_FUNCTION()
{
declare LINE
declare -i INDEX
while read LINE
do
echo "${LINE:3}" > /dev/null
done < "${SUBOR}"
}
time CUT_FUNCTION
echo '-----------------------------------------'
time SED_FUNCTION
echo '-----------------------------------------'
time BASH_BUILTIN_FUNCTION
echo '-----------------------------------------'
a vysledok je, ze sed a cut je v rozmedzi 10 az 20x rychlejsi. Vid vysledok:
real 0m0.003s user 0m0.004s sys 0m0.004s ----------------------------------------- real 0m0.005s user 0m0.004s sys 0m0.000s ----------------------------------------- real 0m0.062s user 0m0.044s sys 0m0.008s -----------------------------------------
Takze ano, mas pravdu a chapem, co vravis. Je pravda, ze som to podal dost jednostranne v predchadzajucom prispevku. Avsak je to vsetko o aktualnej situacii. Za predpokladu, ze nas nic nenuti pouzit vyhranenu mnozinu nastrojov, tak pokial by som cital textovy subor, tak pouzijem sed alebo cut. Ale pokial by na vstupe mali byt premenne, tak urcite bash a jeho schopnosti.
Myslim, ze tedka je to dostatocne ferove. :)
LANG=C program.... Příklad ze života:
bash$ head lags 0.00006891027516632080 -0.00000000850478210449 0.00002081826979675293 -0.00000000850478210449 0.00000087157315521240 0.00003280476159362793 0.00004395083016662598 0.00001094384869537353 0.00000000639637908936 0.00000092118244476318 bash$ wc -l lags 500000 lags bash$ time grep "^-" lags >/dev/null real 0m13.539s user 0m13.426s sys 0m0.017s bash$ time LANG=C grep "^-" lags >/dev/null real 0m0.010s user 0m0.000s sys 0m0.007sneb čtení každého utf-8 znak má režii navíc.
Vdaka za tip s LANG=C .
Bolo pekne vidiet vysledky s LANG=C, ale u mna je to zjavne ine:
pato@debian:~$ head -n10 log 24321 28838 22269 15558 14989 9363 25462 1941 393 8833 pato@debian:~$ wc -l log 1000000 log pato@debian:~$ file --mime-encoding log log: us-ascii pato@debian:~$ locale LANG=en_GB.utf8 LC_CTYPE="en_GB.utf8" LC_NUMERIC="en_GB.utf8" LC_TIME="en_GB.utf8" LC_COLLATE="en_GB.utf8" LC_MONETARY="en_GB.utf8" LC_MESSAGES="en_GB.utf8" LC_PAPER="en_GB.utf8" LC_NAME="en_GB.utf8" LC_ADDRESS="en_GB.utf8" LC_TELEPHONE="en_GB.utf8" LC_MEASUREMENT="en_GB.utf8" LC_IDENTIFICATION="en_GB.utf8" LC_ALL=en_GB.utf8 pato@debian:~$ time grep '^0' log >/dev/null real 0m0.063s user 0m0.048s sys 0m0.020s pato@debian:~$ time LANG=C grep '^0' log >/dev/null real 0m0.063s user 0m0.044s sys 0m0.024s
Mam za to, ze chyba je medzi stolickou a klavesnicou. System funguje s utf8 (vid LC_ALL=en_GB.utf8), subor je ascii (obsahuje nahodne cisla generovane bashom) a zlepsenie ziadne. Vedel by si mi povedat, kde robim chybu ?
p.s.: Som si stiahol aj zdrojove kody pre grep. Som to prehladal, ci nahodou sa nezmenila moda, ale stale je tam
setlocale(LC_ALL,"")
co je presne to, co som nasiel aj na http://www.cl.cam.ac.uk/~mgk25/unicode.html#activate . Som si len chcel overit, ze to tam nie je nejako napevno nastavene vychodzie kodovanie, ak sa ziadne nenajde nastavene. Ale o tom som presvedceny neni a vzhladom na nalez to zjavne funguje, ako je vysvetlene na odkazovanom zdroji.
mbrtowc pro každý znak kopky sena, nebo snad ještě častější jak demonstruje následující:
bash$ wc lags
100 100 1400 lags
bash$ time ltrace grep "^-" lags 2>&1 | LANG=C grep '^mbrtowc(' | wc -l
11633
real 0m2.217s
user 0m0.563s
sys 0m1.790s
Když si projedete začátek toho ltrace logu tak tam také uvidíte jak pracuje s locale.
(Jo, také jsem si kdysi říkal že nejlepší je si přečíst zdrojáky, ale už jsem v paranoidní fázi... a raději trasuji binárku :)).
WAIT_TIME=$(echo "$MSG1" | cut -c4-) nemá hodnotu 30.30 a to je problém ISO-8859-1 (něco z googlu)Vdaka, som si pozrel aj kompletny log z tej diskusie. Je mozne aj takto:
echo "${MSG1:3}"
teda pokial je ta hatlanina a cas ako vstupny retazec. Co som skusil, tak problem ma s tym retazcom iba cut. Nie ale sed alebo bash.
if ( SoftwareAddBOMAutomaticlyToUTF-8(software) ) //is it a stupid software?
{
bool r = DestroyTheSoftwarePernamently (software); //Protect your PC
SendMessageToTheWorld ("DestroyTheSoftwarePernamently", software); //Help protect others
return r; //return true on protect your PC
}
Tiskni
Sdílej: