&reftitle.examples; Crear un fichero Zip open($filename, ZipArchive::CREATE)!==TRUE) { exit("cannot open <$filename>\n"); } $zip->addFromString("testfilephp.txt" . time(), "#1 Esto es una cadena de prueba añadida como testfilephp.txt.\n"); $zip->addFromString("testfilephp2.txt" . time(), "#2 Esto es una cadena de prueba añadida como testfilephp2.txt.\n"); $zip->addFile($thisdir . "/too.php","/testfromfile.php"); echo "numficheros: " . $zip->numFiles . "\n"; echo "estado:" . $zip->status . "\n"; $zip->close(); ?> ]]> Volcar la información del archivo y listarlos open('test_with_comment.zip'); print_r($za); var_dump($za); echo "numFicheros: " . $za->numFiles . "\n"; echo "estado: " . $za->status . "\n"; echo "estadosSis: " . $za->statusSys . "\n"; echo "nombreFichero: " . $za->filename . "\n"; echo "comentario: " . $za->comment . "\n"; for ($i=0; $i<$za->numFiles;$i++) { echo "index: $i\n"; print_r($za->statIndex($i)); } echo "numFichero:" . $za->numFiles . "\n"; ?> ]]> Usando contenedor Zip, leer meta info de OpenOffice open('zip://' . dirname(__FILE__) . '/test.odt#meta.xml'); $odt_meta = array(); while ($reader->read()) { if ($reader->nodeType == XMLREADER::ELEMENT) { $elm = $reader->name; } else { if ($reader->nodeType == XMLREADER::END_ELEMENT && $reader->name == 'office:meta') { break; } if (!trim($reader->value)) { continue; } $odt_meta[$elm] = $reader->value; } } print_r($odt_meta); ?> ]]> Este ejemplo utiliza la antigua API (PHP 4), abre un fichero ZIP, lee cada fichero del archivo y imprime su contenido. El archivotest2.zip usado en este ejmplo es uno de los archivos de prueba la fuente de distribución de ZZIPlib. Ejemplo del uso de Zip ]]>