Americký výrobce čipů Intel propustí 15 procent zaměstnanců (en), do konce roku by jich v podniku mělo pracovat zhruba 75.000. Firma se potýká s výrobními problémy a opouští také miliardový plán na výstavbu továrny v Německu a Polsku.
MDN (Wikipedie), dnes MDN Web Docs, původně Mozilla Developer Network, slaví 20 let. V říjnu 2004 byl ukončen provoz serveru Netscape DevEdge, který byl hlavním zdrojem dokumentace k webovým prohlížečům Netscape a k webovým technologiím obecně. Mozille se po jednáních s AOL povedlo dokumenty z Netscape DevEdge zachránit a 23. července 2005 byl spuštěn MDC (Mozilla Developer Center). Ten byl v roce 2010 přejmenován na MDN.
Wayback byl vydán ve verzi 0.1. Wayback je "tak akorát Waylandu, aby fungoval Xwayland". Jedná se o kompatibilní vrstvu umožňující běh plnohodnotných X11 desktopových prostředí s využitím komponent z Waylandu. Cílem je nakonec nahradit klasický server X.Org, a tím snížit zátěž údržby aplikací X11.
Byla vydána nová verze 6.18 živé linuxové distribuce Tails (The Amnesic Incognito Live System), jež klade důraz na ochranu soukromí uživatelů a anonymitu. Nově se lze k síti Tor připojit pomocí mostu WebTunnel. Tor Browser byl povýšen na verzi 14.5.5. Thunderbird na verzi 128.12.0. Další změny v příslušném seznamu.
Meta představila prototyp náramku, který snímá elektrickou aktivity svalů (povrchová elektromyografie, EMG) a umožňuje jemnými gesty ruky a prstů ovládat počítač nebo různá zařízení. Získané datové sady emg2qwerty a emg2pose jsou open source.
Byla vydána (𝕏) nová verze 25.7 open source firewallové a routovací platformy OPNsense (Wikipedie). Jedná se o fork pfSense postavený na FreeBSD. Kódový název OPNsense 25.7 je Visionary Viper. Přehled novinek v příspěvku na fóru.
Před 40 lety, 23. července 1985, společnost Commodore představila první počítač Amiga. Jednalo se o počítač "Amiga od Commodore", jenž byl později pojmenován Amiga 1000. Mělo se jednat o přímou konkurenci počítače Apple Macintosh uvedeného na trh v lednu 1984.
T‑Mobile USA ve spolupráci se Starlinkem spustil službu T-Satellite. Uživatelé služby mohou v odlehlých oblastech bez mobilního signálu aktuálně využívat satelitní síť s více než 650 satelity pro posílání a příjem zpráv, sdílení polohy, posílání zpráv na 911 a příjem upozornění, posílání obrázků a krátkých hlasových zpráv pomocí aplikace Zprávy Google. V plánu jsou také satelitní data.
Společnost Proxmox Server Solutions stojící za virtualizační platformou Proxmox Virtual Environment věnovala 10 000 eur nadaci The Perl and Raku Foundation (TPRF).
Byla vydána nová verze 2.4.65 svobodného multiplatformního webového serveru Apache (httpd). Řešena je bezpečnostní chyba CVE-2025-54090.
text1
text2
text3
klic_slovo
text4
text5
...
Potreboval bych vysledek asi takto:text1
text2
text3
klic_slovo text4
text5
...
Zkousel jsem to pomoci sedu, awk i grepu, ale k touzenemu vysledku jsem se bohuzel nedostal..
Honza.
Dle
UZITEČNÉ JEDNOŘÁDKOVÉ SKRIPTY PRO SED
je řešení např. toto:
cat file.txt |sed -e :a -e '/klic_slovo$/N; s/\n/ /; ta'
python << EOF import gtk class TwoTexts: def __init__(self, buff, klic_slovo): self.klic_slovo = klic_slovo txtv1 = gtk.TextView() buff1 = txtv1.get_buffer() buff1.set_text(buff) sep = gtk.VSeparator() txtv2 = gtk.TextView() txtv2.set_editable(False) buff2 = txtv2.get_buffer() self.buffer_changed(buff1, buff2) buff1.connect('changed', self.buffer_changed, buff2) hbox = gtk.HBox(False, 0) hbox.pack_start(txtv1, True, True, 0) hbox.pack_start(sep, False, True, 0) hbox.pack_start(txtv2, True, True, 0) hbox.show_all() w = gtk.Window(gtk.WINDOW_TOPLEVEL) w.set_position(gtk.WIN_POS_CENTER) w.connect('destroy', gtk.main_quit) w.connect('delete_event', self.delete_event) w.add(hbox) w.show_all() def delete_event(self, widget, data = None): return False def buffer_changed(self, buff1, buff2): start, end = buff1.get_bounds() text = buff1.get_text(start, end) newtext = text.replace(self.klic_slovo + '\n', self.klic_slovo + ' ') buff2.set_text(newtext) def runapp(self): gtk.main() buff = '''text1 text2 text3 klic_slovo text4 text5''' twotexts = TwoTexts(buff, 'klic_slovo') twotexts.runapp() EOF
cat file.txt |python -c 'import re; import sys; print re.sub(r"(klic_slovo)\n", "\\1 ", sys.stdin.read())'
Na malý soubor je celkem jedno co použijete, ale jakmile bude soubor stejně velký jako vaše RAM, tak jste na tomto příkladu v pythonu skončili (jasný šlo by to vyřešit, ale to by bylo proti Unixové filozofii, proč znovu vymýšlet kolo). Zkuste se podívat na top, když pracuje python a když sed. Všimněte si, že sed nežere žádnou paměť a v tom je jeho síla, je to starý dobrý Unixový nástroj. BTW: sort a další sofistikované nástroje jsou na tom stejně, je jim jedno kolik máte paměti a přece dokončí svojí činost
Zkuste se podívat do /tmp při použití sort na velký soubor a uvidíte proč...
#!/usr/bin/env python import sys k1 = 'klic_slovo\n' k2 = 'klic_slovo ' for line in sys.stdin: if line == k1: line = k2 sys.stdout.write(line)
Sorry, verze na jednom řádku byla jen pro rýpaly a jak jsem se to snažil nahečmat na jeden řádek, tak jsem udělal tu blbost, že jsem nejprve načetl komplet celý vstup do paměti což je moje chyba a ne Pythonu
Nechci tvrdit, že je něco lepší nebo horší, Python mám rád, jen si chci ujasnit na co je lepší se mu vyhnout. Na menší množství dat je bez diskuze pohodlnější po všech stránkách, pokud to není věc, která se jednou napíše přímo do příkazové řádky, již nikdy se nepoužuje a dotyčný zvládá sed, gawk atp.
Myslím, že když chceš srovnávat rychlost, bylo by férové použít i v Pythonu regulární výrazy. Přeci jenom není to vždy takovéto jednoduché porovnávání.
~12x pomalejší:
for line in sys.stdin:
sys.stdout.write(re.sub(r"(klic_slovo)\n", "\\1 ", line))
~6x pomalejší:
pattern1 = re.compile(r"klic_slovo\n")
pattern2 = re.compile(r"(klic_slovo)\n")
for line in sys.stdin:
if (re.search(pattern1, line) == None):
sys.stdout.write(line)
else:
sys.stdout.write(re.sub(pattern2, "\\1 ", line))
Napadá Tě jak to v Pythonu ještě urychlit? Podmínka je samozřejmě zachovat možnost využití regulárních výrazů
Jinak u sedu si můžeme v tomto případě odpustit skákání na značku a, pak je to ještě krapet (opravdu zanedbatelně) rychlejší:
cat file.txt |sed '/klic_slovo$/N; s/\n/ /;'
re.search(pattern1, line)
je podle mých pokusů rychlejší pattern1.search (line)
.
#!/usr/bin/env python import sys, re def run(): search = re.compile(r'(klic_slovo)\n').search write = sys.stdout.write for line in sys.stdin: s = search(line) if s: line = s.groups()[0] + ' ' write(line) run()Ale je to pořád o cca 70% pomalejší než sed nebo perl.
Tiskni
Sdílej: