abclinuxu.cz AbcLinuxu.cz itbiz.cz ITBiz.cz HDmag.cz HDmag.cz abcprace.cz AbcPráce.cz
Inzerujte na AbcPráce.cz od 950 Kč
Rozšířené hledání
×
    včera 23:22 | Nová verze

    Hudební přehrávač Amarok byl vydán v nové major verzi 3.0 postavené na Qt5/KDE Frameworks 5. Předchozí verze 2.9.0 vyšla před 6 lety a byla postavená na Qt4. Portace Amaroku na Qt6/KDE Frameworks 6 by měla začít v následujících měsících.

    Ladislav Hagara | Komentářů: 2
    včera 21:44 | Komunita

    Ubuntu 24.10 bude Oracular Oriole (věštecká žluva).

    Ladislav Hagara | Komentářů: 5
    včera 20:22 | Nová verze

    Byla vydána nová verze 2.45.0 distribuovaného systému správy verzí Git. Přispělo 96 vývojářů, z toho 38 nových. Přehled novinek v příspěvku na blogu GitHubu a v poznámkách k vydání. Vypíchnout lze počáteční podporu repozitářů, ve kterých lze používat SHA-1 i SHA-256.

    Ladislav Hagara | Komentářů: 0
    včera 13:33 | IT novinky

    Před 25 lety, ve čtvrtek 29. dubna 1999, byla spuštěna služba "Úschovna".

    Ladislav Hagara | Komentářů: 0
    včera 01:00 | Nová verze

    Byla vydána nová verze 24.04.28 s kódovým názvem Time After Time svobodného multiplatformního video editoru Shotcut (Wikipedie) a nová verze 7.24.0 souvisejícího frameworku MLT Multimedia Framework. Nejnovější Shotcut je vedle zdrojových kódů k dispozici také ve formátech AppImage, Flatpak a Snap.

    Ladislav Hagara | Komentářů: 0
    28.4. 16:33 | Nová verze Ladislav Hagara | Komentářů: 0
    28.4. 03:22 | Zajímavý článek

    V aktuálním příspěvku na blogu počítačové hry Factorio (Wikipedie) se vývojář s přezývkou raiguard rozepsal o podpoře Linuxu. Rozebírá problémy a výzvy jako přechod linuxových distribucí z X11 na Wayland, dekorace oken na straně klienta a GNOME, změna velikosti okna ve správci oken Sway, …

    Ladislav Hagara | Komentářů: 0
    28.4. 00:11 | Nová verze

    Rakudo (Wikipedie), tj. překladač programovacího jazyka Raku (Wikipedie), byl vydán ve verzi #171 (2024.04). Programovací jazyk Raku byl dříve znám pod názvem Perl 6.

    Ladislav Hagara | Komentářů: 7
    27.4. 17:44 | Nová verze

    Společnost Epic Games vydala verzi 5.4 svého proprietárního multiplatformního herního enginu Unreal Engine (Wikipedie). Podrobný přehled novinek v poznámkách k vydání.

    Ladislav Hagara | Komentářů: 0
    26.4. 17:11 | Nová verze

    Byl vydán Nextcloud Hub 8. Představení novinek tohoto open source cloudového řešení také na YouTube. Vypíchnout lze Nextcloud AI Assistant 2.0.

    Ladislav Hagara | Komentářů: 12
    KDE Plasma 6
     (75%)
     (8%)
     (2%)
     (15%)
    Celkem 883 hlasů
     Komentářů: 4, poslední 6.4. 15:51
    Rozcestník
    Štítky: není přiřazen žádný štítek


    Vložit další komentář
    7.11.2023 13:21 tttttttttttttt
    Rozbalit Rozbalit vše Re: Hlídání logu v Pythonu a Qt5
    A jaké jsou tvé požadavky?
    7.11.2023 13:47 Milan Uhrák | skóre: 31 | blog: milan_at_ABC
    Rozbalit Rozbalit vše Re: Hlídání logu v Pythonu a Qt5
    Hlídat soubor třeba logu. Listovat v něm. Log se obnovuje, takže hlídat znovuvytvoření logu. Barevný výstup je jen šidítko, nemusí umět ( ale při ANSI by to asi vadilo). Less umí listovat, neumí hlídat znovuvytvoření. tail pěkně hlídá znovuvytvoření, neumí listovat.

    Můj prográmek mě naučil zase něco nového z Qt, a dělá všechno tak, jak potřebuju. A ještě mi dělá barvičky :)
    7.11.2023 14:55 RealJ
    Rozbalit Rozbalit vše Re: Hlídání logu v Pythonu a Qt5
    Libi se mi, ze jsi se neco naucil a ze mas tool ktery dela presne to co chces.
    7.11.2023 15:21 Milan Uhrák | skóre: 31 | blog: milan_at_ABC
    Rozbalit Rozbalit vše Re: Hlídání logu v Pythonu a Qt5

    Jako bych slyšel ironii ... ale máš pravdu ...  :-)

    7.11.2023 19:21 Tom
    Rozbalit Rozbalit vše Re: Hlídání logu v Pythonu a Qt5
    Bez ironie, proč QT a ne Electron ?
    7.11.2023 20:21 Milan Uhrák | skóre: 31 | blog: milan_at_ABC
    Rozbalit Rozbalit vše Re: Hlídání logu v Pythonu a Qt5
    Tak v pySide jsem už pár věcí spíchl, trochu Qt znám, a plasma je můj velmi oblíbený desktop. Qt je taky multiplatformní, takže proč se učit kvůli malému nástroji nový jazyk a přístup.
    8.11.2023 00:06 RealJ
    Rozbalit Rozbalit vše Re: Hlídání logu v Pythonu a Qt5
    Bylo to mysleno bez ironie. Sice mi nedava smysl to co s tim delas ale chapu ze kazdy mame jine potreby. A ze se neco naucis je fajn, nebudes za blbce.
    12.11.2023 08:21 Milan Uhrák | skóre: 31 | blog: milan_at_ABC
    Rozbalit Rozbalit vše Re: Hlídání logu v Pythonu a Qt5
    :).. ok, beru
    7.11.2023 16:18 tttttt
    Rozbalit Rozbalit vše Re: Hlídání logu v Pythonu a Qt5
    Co tailspin? Mezi listováním a sledováním jde přepínat, znovuvytvoření myslím dělá stejně jako tail.
    7.11.2023 19:22 ±
    Rozbalit Rozbalit vše Re: Hlídání logu v Pythonu a Qt5
    Umi tailspin i strankovani? (jako more, less)
    8.11.2023 00:34 OldFrog {Ondra Nemecek} | skóre: 36 | blog: Žabákův notes | Praha
    Rozbalit Rozbalit vše Re: Hlídání logu v Pythonu a Qt5
    Ano, pomocí page-up / page-down.
    -- OldFrog
    7.11.2023 16:24 Martin Tůma | skóre: 39 | blog: RTFM | Praha
    Rozbalit Rozbalit vše Re: Hlídání logu v Pythonu a Qt5
    less --follow-name
    Každý má právo na můj názor!
    7.11.2023 16:48 Milan Uhrák | skóre: 31 | blog: milan_at_ABC
    Rozbalit Rozbalit vše Re: Hlídání logu v Pythonu a Qt5
    No ... vidíš, říkal jsem, že man nečtu pořádně .. děkuji , Vyzkoušel jsem a je to to, co jsem víceméně chtěl ... tuhle volbu jsem asi v beznaději přeskočil ...

    M
    8.11.2023 00:28 OldFrog {Ondra Nemecek} | skóre: 36 | blog: Žabákův notes | Praha
    Rozbalit Rozbalit vše Re: Hlídání logu v Pythonu a Qt5
    K danému účelu používám (mimo tail -f) program https://klogg.filimonov.dev anebo https://glogg.bonnefon.org/index.html
    -- OldFrog
    8.11.2023 15:16 Milan Uhrák | skóre: 31 | blog: milan_at_ABC
    Rozbalit Rozbalit vše Re: Hlídání logu v Pythonu a Qt5
    Ten klogg je fakt dobrej .. ještě se mi teda nepovedlo stáhnout verzi pro můj obstarožní Debian 11, ale podle popisu supr.
    8.11.2023 23:17 OldFrog {Ondra Nemecek} | skóre: 36 | blog: Žabákův notes | Praha
    Rozbalit Rozbalit vše Re: Hlídání logu v Pythonu a Qt5
    Jj, používá se fakt příjemně. Já ho stáhnul jako AppImage:

    https://github.com/variar/klogg/releases/tag/continuous-linux
    -- OldFrog
    8.11.2023 22:53 prt
    Rozbalit Rozbalit vše Re: Hlídání logu v Pythonu a Qt5
    Programy tail, more a všechny ostatní metody nesplňovaly moje požadavky ( nebo neumím číst man a google ).
    Nebýval kdysi tohle portál pro fanoušky linuxu?
    10.11.2023 09:20 .:.:.
    Rozbalit Rozbalit vše Re: Hlídání logu v Pythonu a Qt5
    Linux nikdy nemel fanousky. Jenom trpici otroky svazane temnou GPL licenci.
    10.11.2023 00:47 kvr
    Rozbalit Rozbalit vše Re: Hlídání logu v Pythonu a Qt5
    V zásadě pěkné.

    Možná by stálo za to nečíst celý soubor znovu. Na malém logu to je v pohodě, ale pokud něco zapisuje každou chvilku, tak to může docela zahltit a taky budou refresh okna asi dost nepohodlné. Nevím, jestli file watcher reportuje každý zápis nebo jich dá několik dohromady, v prvním případě by to chtělo ignorovat všechno předtím, než se soubor začal načítat.

    Konverze do HTML by měla obsahovat escaping. Replace by mohl být na word boundary, záleží, co je cílem. A pro debugging by nebylo špatné přidat za br textový new line :-)
    Bystroushaak avatar 10.11.2023 02:16 Bystroushaak | skóre: 36 | blog: Bystroushaakův blog | Praha
    Rozbalit Rozbalit vše Re: Hlídání logu v Pythonu a Qt5
    Dá se to řešit přes inotify nebo pokud na tom člověk nechce záviset, tak nějak takhle:
    import os
    import time
    
    
    class TailFIterator:
        """
        Text file iterator, which yields new lines added to the file, like
        tail -F. It can detect when the file descriptor was changed (logrotated) or
        the file was truncated (also used by logrotate).
    
        You can overload:
            .on_file_not_found()
                To change behaviour when the file was followed, but was deleted
                in the process (logrotated). Standard behaviour is to wait 5 seconds,
                try again forever. See also .file_not_found_counter for details.
    
            .on_no_changes_detected()
                To decide what to do when no change was detected. Default is to
                wait 1s.
        """
        def __init__(self, file_path: str, file_mode: str = "rt"):
            self.file_size = 0
            self.file_path = file_path
            self.file_mode = file_mode
    
            self.inode_number = os.stat(file_path).st_ino
            self.logfile = open(file_path, self.file_mode)
    
            self.file_not_found_counter = 0
    
        def __iter__(self):
            while True:
                try:
                    size = self._get_current_size()
                    self.file_not_found_counter = 0
                except FileNotFoundError as e:
                    self.file_not_found_counter += 1
                    self.on_file_not_found(self.file_not_found_counter, e)
                    continue
    
                if size > self.file_size:
                    self.logfile.seek(self.file_size)
                    for line in self.logfile:
                        yield line
                    self.file_size = self.logfile.tell()
    
                # in case the .truncate() was called
                elif size < self.file_size:
                    self._check_and_handle_logrotate()
                    self.file_size = 0
                    continue
    
                if self._check_and_handle_logrotate():
                    continue
    
                self.on_no_changes_detected()
    
        def _get_current_size(self) -> int:
            return os.stat(self.file_path).st_size
    
        def _check_and_handle_logrotate(self) -> bool:
            current_file_info = os.stat(self.file_path)
            current_inode_number = current_file_info.st_ino
            if current_inode_number != self.inode_number:
                self.inode_number = current_file_info.st_ino
                self.logfile = open(self.file_path, self.file_mode)
                self.file_size = 0
    
                return True
    
        def on_file_not_found(self, file_not_found_counter: int, exception):
            if file_not_found_counter > 5:
                raise exception
            time.sleep(5)
    
        def on_no_changes_detected(self):
            time.sleep(1)
    (Psal jsem kdysi pro jeden starší projekt co běžel někde kam jsem nechtěl tahat závislosti).
    10.11.2023 06:02 kvr
    Rozbalit Rozbalit vše Re: Hlídání logu v Pythonu a Qt5
    Ten QFileSystemWatcher už používá inotify (nebo cokoliv relevantního na daném OS) : https://github.com/radekp/qt/blob/master/src/corelib/io/qfilesystemwatcher_inotify_p.h

    Jo, aktivním čekáním se to dá taky, docela zastaralý způsob :-) . Za starých časů jsem psal něco podobného pro PHP a používalo to externí inotify. Dneska už zbytečné, každý jazyk to podoporuje.
    Bystroushaak avatar 10.11.2023 10:11 Bystroushaak | skóre: 36 | blog: Bystroushaakův blog | Praha
    Rozbalit Rozbalit vše Re: Hlídání logu v Pythonu a Qt5
    Jo, čistější by bylo hodit si select na fd, ale tohle mělo svůj důvod :)
    10.11.2023 17:15 kvr
    Rozbalit Rozbalit vše Re: Hlídání logu v Pythonu a Qt5
    select na soubor by nefungoval, bo data jsou přístupná pořád, i když potenciálně jako prázdný read. inotify nebo aktivní kontroly jsou jediný způsob.
    12.11.2023 08:29 Milan Uhrák | skóre: 31 | blog: milan_at_ABC
    Rozbalit Rozbalit vše Re: Hlídání logu v Pythonu a Qt5
    Váš návrh není špatný ale protože to klepu v Qt, (a ještě jsem nevěděl o FileWatcheru), tak jsem to hlídání řešil původně přes QTime. Ale jinak dobrá ukázka, jak řešit problém minimalisticky (co se týče závislostí ) díky

    M
    12.11.2023 08:18 Milan Uhrák | skóre: 31 | blog: milan_at_ABC
    Rozbalit Rozbalit vše Re: Hlídání logu v Pythonu a Qt5
    Pár dní jsem byl na druhém konci světa, už jsem si myslel, že téma uvadlo, a hle, takový gejzír.

    Váš komentář (a také "ukázky z cizí dílny" jako odpověď na ten komentář ) je velmi přínosný. Se znovunačítáním jsem si nedělal hlavu, ale vlastně vidím, že stačí načíst jen "nový kus" toho logu, je přece blbost načítat celý soubor pořád dokola ...

    Tomu word boundary asi nerozumím, v Pythonu něco takového je? Hledal jsem, ale našel jen regexy, což mi moc přínosné nepřipadá, nebo neumím hledat, nebo jste myslel to INFO,DEBUG ... obklíčit mezerami...

    Konverze do HTML by měla obsahovat escaping ... přemýšlím, co jste tím chtěl říci ... jako místo hranatých závorek použít ecsape kódy jako tady na ABC ? Nevím ... možná je to dobrý nápad, ale jen nechápu, co jste tím vlastně myslel ...

    A ten textový newline ... to máte plnou pravdu.. myslel jsem, že při načítání souboru je součástí řetězce, a uloží se do textVieweru, a ejhle ...

    Děkuji za fakt šikovné podněty ... I komentátorům vašeho příspěvku... Zvlášť Jenda musel prohrabávat staré (.. co - prastaré) archivy, aby našel prastarý kód ( i když podle syntaxe možná zase tak prastarý není, ale stejně) ... fakt dík :)

    M
    12.11.2023 08:19 Milan Uhrák | skóre: 31 | blog: milan_at_ABC
    Rozbalit Rozbalit vše Re: Hlídání logu v Pythonu a Qt5
    Tedy ... Liška Bysrouška, ne Jenda, pardon ..
    Bystroushaak avatar 13.11.2023 10:50 Bystroushaak | skóre: 36 | blog: Bystroushaakův blog | Praha
    Rozbalit Rozbalit vše Re: Hlídání logu v Pythonu a Qt5
    Děkuji za fakt šikovné podněty ... I komentátorům vašeho příspěvku... Zvlášť Jenda musel prohrabávat staré (.. co - prastaré) archivy, aby našel prastarý kód ( i když podle syntaxe možná zase tak prastarý není, ale stejně) ... fakt dík :)
    Je to několik let staré, prohledávat jsem nemusel, mám v notionu složku se snippety kam si házím použitelné věci a různé ukázky.
    14.11.2023 19:14 Milan Uhrák | skóre: 31 | blog: milan_at_ABC
    Rozbalit Rozbalit vše Re: Hlídání logu v Pythonu a Qt5
    hmm .. máš to vykoumané ...

    Odkládám tak maximálně do nextcloudu ... občas ...

    Už jsem si říkal, jestli nemáš konečně nějaké napojení desktopu na GPT :-) .. jak jsi onehdá snil ... no počkáme ... a snad se dožijem

    Bystroushaak avatar 24.11.2023 11:35 Bystroushaak | skóre: 36 | blog: Bystroushaakův blog | Praha
    Rozbalit Rozbalit vše Re: Hlídání logu v Pythonu a Qt5
    Chci se k tomu dostat o vánocích, měl bych mít asi 14 dní dovolené. Nedávno jsem koukal že openAI zpřístupnilo asistenty, se kterýma se dá dobře pracovat přes API, dají se pro ně definovat různé funkce které pak můžou volat a taky umí pracovat s (až) 512M soubory. Zkoušel jsem to předevčírem na vyhledávání v PDF a funguje to dost dobře*. Co chci vyzkoušet je jak moc se dají použít i mimo vyhledávání, z toho co jsem zatím viděl, tak to v tom sandboxu i může vyrábět soubory, takže by to mělo být použitelné i pro věci jako generování a transformace (třeba tam nahraješ blog, řekneš mu ať ti ho přeloží do jiného jazyka, a on vyplivne rovnou soubor s překladem).

    *Různé abstraktní dotazy, typu najdi mi kde v knize se mluví o tomhle a tomhle, nebo kde všude se řeší tohle téma.
    27.11.2023 08:28 Milan Uhrák | skóre: 31 | blog: milan_at_ABC
    Rozbalit Rozbalit vše Re: Hlídání logu v Pythonu a Qt5
    Tak přeju, ať se zadaří... Tohle moc neznám, tudíž jen závistivé koukám ..
    14.11.2023 04:48 kvr
    Rozbalit Rozbalit vše Re: Hlídání logu v Pythonu a Qt5
    \b(ERROR|INFO|WARN)\b

    Výhoda je, že to nebude matchovat třeba information nebo terror.

    Escape HTML - například <1> by se měla změnit na &lt;1&gt; , jinak to může být hezký námět nat code injection :-)

    S těmi newline a načítáním nového souboru - bude tam nějaká komplexita navíc, neboť match či přidání nového řádku by se mělo dít jenom v případech, kdy se dokončilo načtení aspoň jednoho řádku. To jenom detail, když už to tak komplikuju.
    14.11.2023 19:28 Milan Uhrák | skóre: 31 | blog: milan_at_ABC
    Rozbalit Rozbalit vše Re: Hlídání logu v Pythonu a Qt5
    Děkuji za dovysvětleni ...

    Jelikož ten můj log ( ale zase by ten prográmek měl být trošku univerzální, tak nevím ) má [ERROR], hodím tam i hranaté jako možnost. Donačítání souboru už funguje, pokud je nový soubor menší než předtím, vypíše se i hláška o resetování ... to donačítání je výkonově perfektní návrh. Moje logy jsou síce zatím malé, ale kdoví, jak se to vše vyvine .. takže toto byla dobrá připomínka.. no ale zase když je tu klogg ... tak už je ten můj prográmek leda na hraní, nebo zkusit si něco víc, než zatím umím.

    A zkusím udělat i tu ANSI konverzi .. Našel jsem hotovou Python třídu na githubu, tak to bude taky zdroj námětů ( autor to tam bere seširoka, a zpracovává i kódy posunu a všeho možného, exportuje to do (asi) latexu, no mám představu něčeho kratšího.

    Jinak díky..

    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.