RarArchive::getEntries
rar_list
(PECL rar >= 2.0.0)
RarArchive::getEntries -- rar_list — Возвращает полный список элемнтов из RAR архива
Описание
Объектно-ориентированный стиль (method):
Процедурный стиль:
Возвращает эелемны (файлы и директории) из RAR архива.
Замечание:
Если архив имеет элементы с одинаковым именем, то этот метод совместно с циклом foreach по RarArchive и доступом к нему как к массиву с числовыми индексами являются единствунными способами получить доступ к этим элементам (т.е. RarArchive::getEntry() и rar:// обработчик (wrapper) не помогут).
Возвращаемые значения
rar_list() возращает массив объектов RarEntry
или FALSE
в случае возникновения ошибки.
Список изменений
Версия | Описание |
---|---|
3.0.0 | Исправлена поддержка RAR архивов с повторяющимися именами элементов. |
Примеры
Пример #1 Объектно-ориентированный стиль
<?php
$rar_arch = RarArchive::open('solid.rar');
if ($rar_arch === FALSE)
die("Could not open RAR archive.");
$rar_entries = $rar_arch->getEntries();
if ($rar_entries === FALSE)
die("Could retrieve entries.");
echo "Found " . count($rar_entries) . " entries.\n";
foreach ($rar_entries as $e) {
echo $e;
echo "\n";
}
$rar_arch->close();
?>
Результатом выполнения данного примера будет что-то подобное:
Found 2 entries. RarEntry for file "tese.txt" (23b93a7a) RarEntry for file "unrardll.txt" (2ed64b6e)
Пример #2 Процедурный стиль
<?php
$rar_arch = rar_open('solid.rar');
if ($rar_arch === FALSE)
die("Could not open RAR archive.");
$rar_entries = rar_list($rar_arch);
if ($rar_entries === FALSE)
die("Could retrieve entries.");
echo "Found " . count($rar_entries) . " entries.\n";
foreach ($rar_entries as $e) {
echo $e;
echo "\n";
}
rar_close($rar_arch);
?>
Смотрите также
- RarArchive::getEntry() - Возвращает объект элемента из RAR архива
- rar:// обработчик(wrapper)
- PHP Руководство
- Функции по категориям
- Индекс функций
- Справочник функций
- Расширения для сжатия и архивации
- Архивирование Rar
- Функция RarArchive::close() - Закрывает RAR архив и освобождает все ресурсы
- Функция RarArchive::getComment() - Get comment text from the RAR archive
- Функция RarArchive::getEntries() - Возвращает полный список элемнтов из RAR архива
- Функция RarArchive::getEntry() - Возвращает объект элемента из RAR архива
- Функция RarArchive::isBroken() - Test whether an archive is broken (incomplete)
- Функция RarArchive::isSolid() - Check whether the RAR archive is solid
- Функция RarArchive::open() - Открывает RAR архив
- Функция RarArchive::setAllowBroken() - Whether opening broken archives is allowed
- Функция RarArchive::__toString() - Get text representation
Коментарии
Can be usefult for many, probably:
<?php
$path = 'path/to/archive';
$archive = RarArchive::open($path);
$list = $archive ->getEntries();
foreach ($list as $entity) {
//print just title of file from archive(use getters to access other fields, etc)
echo $value->getName();
}
?>
at the examples line 7 should be:
die("Could NOT retrieve entries.");