LINUXSOFT.cz Přeskoč levou lištu
Uživatel: Heslo:  
   CZUKPL

> Perl (113) - Práce s archivy

Perl Budeme se věnovat práci s archivy, zejména pak rozbalování a zabalování. Zajímat nás budou nejrozšířenější formáty tar, zip a rar.

12.7.2010 00:00 | Jiří Václavík | Články autora | přečteno 5515×

Podívejme na to, jak manipulovat s TAR, ZIP a RAR v Perlu.

Budeme používat zejména modul Archive::Tar, jelikož tento typ archivu je v linuxovém světě asi nejrozšířenější.

Archive::Tar je sice jako modul pomalý a občas náročný na paměť, ale díky implementaci pomocí perlu je snadno přenositelný.

Vytvoření objektu pro manipulaci s archivy

Pro jakoukoliv manipulaci s archivy je třeba vždy vytvořit Tar objekt. To se dělá standardní cestou metodou new.

$tar = Archive::Tar->new("priklad.tar");

Je-li uvedeno jméno archivu jako parametr, pak se z něj provedením tohoto příkazu se do operační paměti načte seznam souborů. S těmito soubory tak můžeme dále pracovat.

Pro vymazání seznamu souborů z paměti lze využít metodu clear a pro znovunačtení metody read.

Přidávání se provádí metodou add_files a přejmenování pomocí rename.

Kontrola obsahu archivu

Pomocí metody contains_file lze ověřit, zda archiv obsahuje zadaný soubor.

$tar->contains_file("index.html");

Chceme-li zkontrolovat celý obsah, pak oceníme spíše funkci list_files, která vrátí seznam názvů všech souborů.

Pokud se nechceme obtěžovat s vytvářením objektů, lze pro získání seznamu souborů v archivu archiv.tar zadat také následující.

Archive::Tar->list_archive("archiv.tar");

Rozbalování

Metoda read slouží k načtení komprimovaného souboru do paměti. Jejími argumenty jsou jméno komprimovaného souboru a jako třetí parametr odkaz na hash s pevně určenou strukturou, který ovlivní, kolik a jaké soubory mají být z vybaleny z archivu.

Návratová hodnota funkce read je pole obsahující názvy rozbalených souborů.

Po volání read máme obsah k rozbalení načten v paměti. Samotné rozbalení provede jedna z metod extract nebo extract_file.

Podívejme se na možné klíče hashe parametrů ve volání metody read.

KlíčVýznam
filterpomocí regulárního výrazu určí, vybere jen některé soubory
extractnastavíme-li hodnotu na 1, pak se automaticky zavolá metoda extract (a archiv bude rozbalen)
limitomezí počet rozbalovaných souborů na uvedené množství

Chceme-li rozbalit soubor priklad.tar, pak tedy dle výše uvedeného napíšeme následující kód.

use Archive::Tar;
my $tar = Archive::Tar->new;
$tar->read("priklad.tar");
$tar->extract();

Uvedeme-li parametr extract s pravdivou hodnotou, pak lze program zredukovat o poslední řádek.

use Archive::Tar;
my $tar = Archive::Tar->new;
$tar->read("priklad.tar", "", {"extract"=>1});

Pro rozbalení pouze souborů s příponou html použijeme klíč filter.

$tar->read("priklad.tar", "", {"extract"=>1, "filter"=>'.*html\$'});

Pro vybalení jednoho souboru zde máme metodu extract_file. Zde můžeme jako druhý parametr zadat, kam se má vybalený soubor přesunout.

Pokud nám jde pouze o rozbalení běžného archivu, pak jistě oceníme metodu třídy extract_archive. Ta funguje následovně.

Archive::Tar->extract_archive("priklad.tar");

Důkladnější výběr rozbalovaných souborů

Soubor rozbalený pomocí Archive::Tar se stává objektem typu Archive::Tar::File. To nám přináší zejména možnost filtrovat soubory podle dalších kritérií.

Uveďme si některá kritéria v tabulce.

KritériumVýznam
namejméno souboru
sizevelikost souboru v bajtech
typetyp souboru; Archive::Tar pro tento účel exportuje konstanty FILE, HARDLINK, SYMLINK, CHARDEV, BLOCKDEV, DIR, FIFO, SOCKET
mktimečas poslední modifikace
modemód
uid, gid, uname, gnameuživatel, skupina vlastnící soubor

Pak lze provádět takové věci jako například rozbalení souborů, jejichž velikost nepřesahuje 1000 bajtů. To by se provedlo takto.

$tar->extract(grep {$_->size < 1000 } $tar->get_files);

Taktéž lze rozbalovat podle obsahu souboru. Existuje metoda get_content, jež vrací obsah souboru. Pro rozbalení pouze těch souborů, které obsahují slovo linuxsoft provedeme následující příkaz.

$tar->extract(grep {$_->get_content =~ /linuxsoft/i} $tar->get_files);

Existují další zajímavé metody pro objekty typu Archive::Tar::File, o nichž se lze dočíst v dokumentaci.

Zabalování

Do tvořeného archivu se vždy vloží soubory, které jsou aktuálně v paměti. Ovšem jak přidat další soubory? K tomu máme metodu add_files, které předáme seznam souborů.

Přidání souboru tar.pl do našeho virtuálního seznamu tak provedeme následujícím voláním.

$tar->add_files("tar.pl");

Archivy se zabalují metodou write. Musíme vždy uvést co zabalit a jak to zabalit.

Prvním argumentem určujeme soubor, kam se archiv zapíše. Druhým je pro gzip úroveň komprese od 1 nebo 9 nebo pro bzip2 hodnota COMPRESS_BZIP.

Pro vytvoření nového archivu ze souborů v paměti lze užít například následující příkaz.

$tar->write("novy_archiv.tgz", 9);

Rychlejší cesta pro vytvoření archivu vede přes metodu třídy. Aniž bychom vytvářeli objekt, můžeme volat metodu create_archive. Té předáme požadovaný název výsledného archivu, typ komprese a seznam souborů, které chceme zabalit. Na ukázku přiložme tento příkaz.

Archive::Tar->create_archive( "vysledek.tgz", COMPRESS_GZIP, "tar.pl", "formular.html");

Práce se ZIP archivy

Myšlenka u práce se ZIP archivy je podobná jako u TAR archivů a proto se v rychlosti podívejme na základní operace.

Opět je třeba na začátku načíst archiv, který budeme rozbalovat. To provedeme pomocí metody new.

use Archive::Zip;
my $zip = Archive::Zip->new("archiv.zip");

Poznamenejme, že i zde je k dispozici metoda read, kterou lze přidávat nové soubory z archivů.

Seznam souborů z archivu archiv.zip nyní máme k dispozici. Pro seznam jmen souborů z tohoto archivu stačí zavolat metodu memberNames.

print $zip->memberNames;

Rozbalení proběhne po zavolání metody extractMember. Jako parametr uvedeme seznam souborů, které se mají rozbalit.

$zip->extractMember("titulky.sub");

Se seznamem souborů můžeme volně manipulovat. Pro odstranění některého souboru použijeme metodu removeMember.

$zip->removeMember("nepotrebny_soubor");

Naopak pro přidání souboru využijeme metodu addFile. Do nově tvořeného archivu lze nový soubor přidat pod změněným jménem.

$zip->addFile("data", "nove_jmeno")

Máme-li seznam souborů připraven, můžeme je zabalit.

$zip->writeToFileNamed("vysledek.zip");

Možností Archive::Zip je více. Pokročilejší záležitosti lze nalézt v dokumentaci.

Práce s RAR archivy

Pro rozbalení RAR archivu lze použít následující sekvenci příkazů.

use Archive::Rar;
$rar = Archive::Rar->new(-archive => "archiv.rar");
$rar->List;
$rar->Extract;

Další moduly

Existuje univerzální modul Archive::Extract, který dokáže rozbalit soubory různých typů. Jeho použití je následující.

use Archive::Extract;
$extract = Archive::Extract->new(archive => "priklad.tar");
$extract->extract;

Naopak dalším modulem zaměřeným na vytváření archivů je Archive::Builder.

Mimo uvedené existuje řada dalších modulů tvaru Archive::.

Verze pro tisk

pridej.cz

 

DISKUZE

Nejsou žádné diskuzní příspěvky u dané položky.



Příspívat do diskuze mohou pouze registrovaní uživatelé.
> Vyhledávání software
> Vyhledávání článků

18.6.2013 7:01 /MaReK Olšavský
Ač se to zdá neuvěřitelné, případ SCO vs. IBM je otevřený. Znovu jej otevřel soud v Utahu, na žádost ještě stále „kopající“ SCO Group. O výsledku případu je těžké polemizovat. Kolem Linuxu se točí velké množství peněz a kdyby dovedlo SCO vybírat poplatky jen za komerční nasazení, možná by mělo příjmy srovnatelně s Red Hatem.
Přidat komentář

18.6.2013 7:01 /MaReK Olšavský
Přehrávač Songbird, vyvíjený nad jádrem Gecko, nikdy výrazně neprosadil a od roku 2010 není vyvíjen pro Linux. Eric Wirttman oznámil ukončení projektu k 28. červnu. Zvedne někdo hozenou rukavici, nebo skončí Songbird na smetišti zapomenutých projektů?
Komentářů: 1

17.6.2013 6:54 /MaReK Olšavský
Velký přínos pro tržní podíl MariaDB bude znamenat Red Hat Enterprise Linux, který je dalším řadě distribucí přecházejících od MySQL na MariaDB. Vývojáři MariaDB získají, díky síle Red Hatu, významnou pozici na trhu databází.
Přidat komentář

17.6.2013 6:54 /MaReK Olšavský
Nedlouho po vydání Debianu 7 vychází upgradovaný Debian 7.1, který přináší bezpečnostní opravy. Vydání je určené jen pro prvotní instalaci, updaty z repozitářů již problémy řešily.
Přidat komentář

14.6.2013 7:16 /MaReK Olšavský
Příjemnou zprávou ze sousedního Německa je oficiální odmítání softwarových patentů v německém parlamentu (Bundestagu). Při síle Německa v EU a světě jde o výrazný posun na cestě k jejich zabránění. Méně příjemnou je zamítnutí přechodu Berlína na GNU/Linux (alespoň prozatím, třeba se časem ledy pohnou).
Přidat komentář

13.6.2013 7:13 /MaReK Olšavský
Jim Whitehurst, CEO Red Hatu, vysvětloval na Red Hat Summitu, že svobodný software není jen o ceně, ale především je hlavním nositelem inovací. Mnoho zajímavých inovací určitě přinese i připravovaný RHEL 7, ale desktopové uživatele bude nejspíše nejvíce zajímat změna desktopu na GNOME 3 Classic mode.
Přidat komentář

13.6.2013 7:13 /MaReK Olšavský
Vývoj Waylandu bohužel nepokračuje tak, jak by bylo potřeba a někteří vývojáři ztrácí motivaci pro další práci. Problémem je testování a připravenost navazujícího software (Cairo) a chyby v potřebných ovladačích (Mesa).
Komentářů: 1

12.6.2013 7:11 /MaReK Olšavský
Na stránkách LinuxInsider vyšel rozhovor s Danielem Robbinsem, jenž byl zakladatelem distribuce Gentoo. Gentoo vytvořil během své práce na místě administrátora univerzity v Novém Mexiku a dnes je aktivní jako komunitní manager projektu Zenoss.
Přidat komentář

   Více ...   Přidat zprávičku

> Poslední diskuze

18.6.2013 22:21 / Petr Ježek
???

17.6.2013 18:24 / Karel Belunek
Super!!!

16.6.2013 14:32 / Petr Ježek
jeden ztratil

12.6.2013 13:39 / Petr Ježek
E17

10.6.2013 13:31 / Petr Ježek
Lépe?

Více ...

ISSN 1801-3805 | Provozovatel: Pavel Kysilka, IČ: 72868490 (2003-2013) | mail at linuxsoft dot cz | Design: www.megadesign.cz | Textová verze | zákony online