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 23:33 | Nová verze

    Richard Biener oznámil vydání verze 16.1 (16.1.0) kolekce kompilátorů pro různé programovací jazyky GCC (GNU Compiler Collection). Jedná se o první stabilní verzi řady 16. Přehled změn, nových vlastností a oprav a aktualizovaná dokumentace na stránkách projektu. Některé zdrojové kódy, které bylo možné přeložit s předchozími verzemi GCC, bude nutné upravit.

    Ladislav Hagara | Komentářů: 0
    včera 23:11 | Nová verze

    Zulip Server z open source komunikační platformy Zulip (Wikipedie, GitHub) byl vydán ve verzi 12.0. Přehled novinek v příspěvku na blogu.

    Ladislav Hagara | Komentářů: 0
    včera 12:11 | IT novinky

    Před 30 lety, tj. v úterý 30. dubna 1996, byl spuštěn Seznam.cz.

    Ladislav Hagara | Komentářů: 4
    včera 11:44 | Komunita

    Byly zpracovány a zveřejněny všechny videozáznamy, které stojí za zveřejnění, z konference FOSDEM 2026.

    Ladislav Hagara | Komentářů: 0
    včera 01:11 | IT novinky

    Od úterý 28. dubna musí nově uváděné notebooky v Evropské unii podporovat nabíjení přes USB-C. Jednotná nabíječka byla schválena Evropským parlamentem v říjnu 2022.

    Ladislav Hagara | Komentářů: 53
    29.4. 23:44 | Bezpečnostní upozornění

    Byly publikovány informace o kritické zranitelnosti CVE-2026-31431 pojmenované Copy Fail v Linuxu, konkrétně v kryptografii (AF_ALG). Běžný uživatel může získat práva roota (lokální eskalaci práv). Na všech distribucích Linuxu vydaných od roku 2017. Pomocí 732bajtového skriptu. V upstreamu je již opraveno. Zranitelnost byla nalezena pomocí AI Xint Code.

    Ladislav Hagara | Komentářů: 4
    29.4. 17:44 | Nová verze

    Textový editor Zed dospěl do verze 1.0. Představení v příspěvku na blogu.

    Ladislav Hagara | Komentářů: 0
    29.4. 04:44 | Komunita

    Vývojáři svobodného 3D softwaru Blender představili (𝕏, Mastodon, Bluesky) nejnovějšího firemního sponzora Blenderu. Je ním společnost Anthropic stojící za AI Claude a úroveň sponzoringu je Patron, tj. minimálně 240 tisíc eur ročně. Anthropic oznámil sponzorství v tiskové zprávě Claude for Creative Work.

    Ladislav Hagara | Komentářů: 7
    29.4. 03:55 | Nová verze

    VNC server wayvnc pro Wayland kompozitory postavené nad wlroots - ne GNOME, KDE nebo Weston - byl vydán ve verzi 0.10.0. Vydána byla také verze 1.0.0 související knihovny neatvnc.

    Ladislav Hagara | Komentářů: 0
    28.4. 16:22 | Nová verze

    Bylo oznámeno vydání Fedora Linuxu 44. Ve finální verzi vychází šest oficiálních edic: Fedora Workstation a Fedora KDE Plasma Desktop pro desktopové, Fedora Server pro serverové, Fedora IoT pro internet věcí, Fedora Cloud pro cloudové nasazení a Fedora CoreOS pro ty, kteří preferují neměnné systémy. Vedle nich jsou k dispozici také další atomické desktopy, spiny a laby. Podrobný přehled novinek v samostatných článcích na stránkách

    … více »
    Ladislav Hagara | Komentářů: 7
    Které desktopové prostředí na Linuxu používáte?
     (14%)
     (8%)
     (2%)
     (13%)
     (31%)
     (3%)
     (6%)
     (3%)
     (15%)
     (24%)
    Celkem 1467 hlasů
     Komentářů: 30, poslední 3.4. 20:20
    Rozcestník

    Dotaz: Načtení souborů v Pythonu

    10.11.2015 17:59 pavel
    Načtení souborů v Pythonu
    Přečteno: 2076×
    Jak v Pythonu 2.7 načíst z adresáře na disku názvy několika souborů (i s cestami) do samostatných proměnných?

    Např.:
    /home/pavel/texty/dopis1.txt
    /home/pavel/texty/vysledky.txt
    /home/pavel/texty/zapis.txt
    ...
    ...
    ...
    Požadovaný výsledek:
    obsah_promenne1_ma_byt: /home/pavel/texty/dopis1.txt
    obsah_promenne2_ma_byt: /home/pavel/texty/vysledky.txt
    obsah_promenne3_ma_byt: /home/pavel/texty/zapis.txt

    Řešení dotazu:


    Odpovědi

    10.11.2015 18:25 NN
    Rozbalit Rozbalit vše Re: Načtení souborů v Pythonu
    10.11.2015 22:54 pavel
    Rozbalit Rozbalit vše Re: Načtení souborů v Pythonu
    Dobře, os.walk. Dal sem tedy do testovacího souboru:

    for (path, dirs, files) in os.walk(path):
    print path
    print files

    A výstup testu je správný:

    /home/pavel/texty
    ['dopis1.txt', 'vysledky.txt', 'zapis.txt']

    Jak ale načíst názvy souborů (i s cestami) do samostatných proměnných?

    Prostě, aby se v první proměnné objevil obsah /home/pavel/texty/dopis1.txt, v druhé proměnné /home/pavel/texty/vysledky.txt, atd.
    Řešení 1× (pet I.)
    10.11.2015 23:43 NN
    Rozbalit Rozbalit vše Re: Načtení souborů v Pythonu
    Pro zobrazeni cele cesty pouzij:
    os.path.join(root,name)
    Je to take v dokumentaci v odkazu. Mimochodem, jak vis kolik bude tech souboru?
    13.11.2015 21:57 pavel
    Rozbalit Rozbalit vše Re: Načtení souborů v Pythonu
    Díky, to je ono. Přesně tak to řeší i v knížce o Pythonu, kterou sem mezitím sehnal. Mimochodem soubory budou napevno 4.

    Označte prosím někdo tuto odpověď NN za řešení.

    Bystroushaak avatar 11.11.2015 12:04 Bystroushaak | skóre: 36 | blog: Bystroushaakův blog | Praha
    Rozbalit Rozbalit vše Re: Načtení souborů v Pythonu
    Jak ale načíst názvy souborů (i s cestami) do samostatných proměnných?

    Prostě, aby se v první proměnné objevil obsah /home/pavel/texty/dopis1.txt, v druhé proměnné /home/pavel/texty/vysledky.txt, atd.
    Dá se to vyřešit třeba takhle:
    #! /usr/bin/env python
    # -*- coding: utf-8 -*-
    #
    import os
    import os.path
    
    
    path = "."
    for cnt, fn in enumerate(os.listdir(path)):
        fn = os.path.abspath(fn)
        if os.path.isfile(fn):
            key = "obsah_promenne%d_ma_byt" % (cnt + 1)
            globals()[key] = fn
    
    
    print obsah_promenne1_ma_byt
    print obsah_promenne2_ma_byt
    print obsah_promenne3_ma_byt
    
    Ale docela silně pochybuji, že to je to co chceš. Mít tisíc proměnných ti k ničemu není, většinou to chceš nějak sekvenčně zpracovávat, nebo je mít v poli.
    13.11.2015 01:34 pavel
    Rozbalit Rozbalit vše Re: Načtení souborů v Pythonu
    Pokud by to fungovalo, je to přesně to, co chci a potřebuju. Jenže ten tvuj kód nefunguje.

    Traceback (most recent call last):
    print obsah_promenne2_ma_byt
    NameError: name 'obsah_promenne2_ma_byt' is not defined

    Kompletní hlášení mi abclinuxu nevzalo, protože prý obsahuje zakázanou značku. Nevim, na co tu teda mají to code
    13.11.2015 10:26 chrono
    Rozbalit Rozbalit vše Re: Načtení souborů v Pythonu
    Ten kód funguje, ale preskakuje adresáre, takže sa môže stať, že sa nejaké číslo preskočí. Taktiež nastane problém keď bude tých súborov menej (ale to ti už písali a ty si to ignoroval). A písali aj to, že takmer určite toto nie je spôsob, akým by sa to malo riešiť.

    PS: Code a pre fungujú, a keďže sa používa html, tak je logické, že znak < musí byť nahradený entitou &lt;.
    Bystroushaak avatar 13.11.2015 20:11 Bystroushaak | skóre: 36 | blog: Bystroushaakův blog | Praha
    Rozbalit Rozbalit vše Re: Načtení souborů v Pythonu
    Nevim, na co tu teda mají to code
    Code je jen HTML značka <code>, která z principu není vševědoucí (doslova to nejde parsovat bez escapování), takže jí musíš vyescapovat < a > za &lt; &gt;.
    Jenže ten tvuj kód nefunguje.

    Ale funguje. Jen to musíš pustit v adresáři, kde jsou alespoň tři soubory, jinak nemůžeš čekat, že to naplní tři proměnné, že.
    13.11.2015 21:50 pavel
    Rozbalit Rozbalit vše Re: Načtení souborů v Pythonu
    V tom adresáři byly 4 soubory, takže ze mně prosím nedělej vo*a.

    Naštěstí sem to ještě předtím vyřešil podle knížky, kterou sem mezitím sehnal. Kód z knížky funguje perfektně (na rozdíl od toho tvého nefunkčního).

    Úkol je vyřešen, dál mne Python nezajímá. Vracím se ke své milované Javě, ve které dělám už několik let.
    Bystroushaak avatar 13.11.2015 23:58 Bystroushaak | skóre: 36 | blog: Bystroushaakův blog | Praha
    Rozbalit Rozbalit vše Re: Načtení souborů v Pythonu
    Je pravda, že jsem tam udělal chybu, za což se omlouvám. Teď když na to koukám, tak se ten counter incrementuje vždycky, i když se má incrementovat jen v případě že je to soubor. Zábavné ale je, že na setu dat který jsi popsal to fungovalo správně, což znamená že to ve skutečnosti pouštíš na jiném.
    #! /usr/bin/env python
    # -*- coding: utf-8 -*-
    #
    import os
    import os.path
    
    path = "."
    files = (
        os.path.abspath(fn)
        for fn in os.listdir(path)
        if os.path.isfile(fn)
    )
    
    for cnt, fn in enumerate(files):
        key = "obsah_promenne%d_ma_byt" % (cnt + 1)
        globals()[key] = fn
    
    print obsah_promenne1_ma_byt
    print obsah_promenne2_ma_byt
    print obsah_promenne3_ma_byt
    
    Úkol je vyřešen, dál mne Python nezajímá. Vracím se ke své milované Javě, ve které dělám už několik let.

    Zhrzený Java programátor? Příště to napiš rovnou, ušetříš všem dost času.
    rADOn avatar 11.11.2015 17:55 rADOn | skóre: 44 | blog: bloK | Praha
    Rozbalit Rozbalit vše Re: Načtení souborů v Pythonu
    Jeste by to neskodilo sesortit. Ale souhlasim ze fungujici reseni je k nicemu a autor zjisti ze to co chce neni to co potrebuje…
    "2^24 comments ought to be enough for anyone" -- CmdrTaco
    15.11.2015 20:12 Milan Uhrák | skóre: 31 | blog: milan_at_ABC
    Rozbalit Rozbalit vše Re: Načtení souborů v Pythonu
    Jestli autor dělá v javě již několik let - nemůže být toto důvod, proč se nám zdají java programy děsně pomalé ? :-D

    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.