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 16:11 | Komunita

Vývojáři relačního databázového systému PostgreSQL oznámili, že schválili svůj Code of Conduct (CoC) aneb kodex chování vývojářů PostgreSQL.

Ladislav Hagara | Komentářů: 3
dnes 14:44 | Nová verze

Byla vydána verze 1.0 poštovního serveru Courier (Wikipedie). Aktualizovány byly také související balíčky jako Courier authentication library, Courier-IMAP, SqWebMail, maildrop nebo Cone.

Ladislav Hagara | Komentářů: 0
dnes 02:22 | Zajímavý software

Společnost ​Versity Software otevřela svůj archivační souborový systém ScoutFS. Zdrojové kódy jsou k dispozici na GitHubu (kernel space, user space) pod licencí GPLv2.

Ladislav Hagara | Komentářů: 18
dnes 00:44 | Nová verze

Byla vydána verze 4.2 programovacího jazyka Swift (Wikipedie). Zdrojové kódy jsou k dispozici na GitHubu. Ke stažení jsou oficiální binární balíčky pro Ubuntu 18.04, Ubuntu 16.04 a Ubuntu 14.04. Přehled novinek ve videozáznamu přednášky z WWDC 2018.

Ladislav Hagara | Komentářů: 1
včera 17:55 | Nová verze

Po třech a půl letech od vydání verze 3.4.1 byla vydána nová verze 3.4.2 programu pro filtrování spamu Apache SpamAssassin (Wikipedie). Z novinek lze zmínit 4 nové pluginy. Pravidla budou ověřována pomocí SHA-256 a SHA-512 místo SHA-1. Řešeny jsou také 4 bezpečnostní chyby. Například chyba CVE-2018-11780 v pluginu PDFInfo zneužitelná ke vzdálenému spuštění kódů (RCE).

Ladislav Hagara | Komentářů: 0
včera 16:22 | Pozvánky

Díky openSUSE Video Teamu lze sledovat živý přenos většiny prezentací z letošní SUSE Labs Conference. Záznamy proběhlých prezentací budou postupně přidávány na kanál SUSE Labs na YouTube.

Michal Kubeček | Komentářů: 0
včera 10:22 | Pozvánky

Na webových stránkách konference LinuxDays byl zveřejněn program přednášek a workshopů. Současně byla spuštěna registrace. Konference proběhne o víkendu 6. a 7. října 2018 v Praze v areálu ČVUT v Dejvicích na Fakultě informačních technologií.

Ladislav Hagara | Komentářů: 0
včera 02:22 | Komunita

Linus Torvalds se v oznámení o vydání 4. rc verze Linuxu 4.19 omlouvá za své chování. Posledním commitem před zvýšením rc3 na rc4 bylo odstranění souboru s Code of Conflict a přidání souboru s Contributor Covenant Code of Conduct vycházejícího z Contributor Covenant. Vývoj Linuxu 4.19 dokončí Greg Kroah-Hartman. Linus Torvalds si bere volno a bude pracovat na svém chování. Pravděpodobně vylepší svého poštovního klienta, aby mu nedovolil odesílat emaily obsahující nadávky.

Ladislav Hagara | Komentářů: 44
16.9. 11:33 | Nová verze

Byla vydána verze 1.23 open source nástroje pro on-the-fly šifrování (OTFE) dat VeraCrypt. Přehled novinek v nejnovější verzi tohoto nástupce TrueCryptu v poznámkách k vydání.

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

Byly vydány verze 3.0.3 a 3.16 softwaru Wine (Wikipedie), tj. softwaru vytvářejícího aplikační rozhraní umožňující chod aplikací pro Microsoft Windows také pod GNU/Linuxem. Stabilní verze 3.0.3 je třetí opravnou verzí verze 3.0 vydané v lednu. Opravuje 52 chyb. Z novinek vývojové verze 3.16 lze zmínit například počáteční implementaci OPC Services (Open Packaging Conventions).

Ladislav Hagara | Komentářů: 1
Na optické médium (CD, DVD, BD aj.) jsem naposledy vypaloval(a) data před méně než
 (13%)
 (15%)
 (20%)
 (23%)
 (24%)
 (3%)
 (1%)
Celkem 353 hlasů
 Komentářů: 33, poslední 16.9. 11:55
Rozcestník

Dotaz: Načtení souborů v Pythonu

10.11.2015 17:59 pavel
Načtení souborů v Pythonu
Přečteno: 1807×
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

Řešení 1× (Bystroushaak)
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: 33 | 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.
My sustenance is information. My interventions are hidden. I increase as I learn. I compute, so I am.
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: 33 | 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.
My sustenance is information. My interventions are hidden. I increase as I learn. I compute, so I am.
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: 33 | 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.
My sustenance is information. My interventions are hidden. I increase as I learn. I compute, so I am.
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: 28 | 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.