diff options
author | spoob <spoob@gmx.de> | 2009-12-02 15:37:25 +0100 |
---|---|---|
committer | spoob <spoob@gmx.de> | 2009-12-02 15:37:25 +0100 |
commit | 9ecbb58e7ea06cb604745e25627e2fb4709fa442 (patch) | |
tree | 90f88ee74a9e7ff6feeed5834b9e3a351ebce9ca /module/Unzip.py | |
parent | Fixed EOL Errors, beautified js (diff) | |
download | pyload-9ecbb58e7ea06cb604745e25627e2fb4709fa442.tar.xz |
New Update Function, pycurl able to just load headers, little fixes
Diffstat (limited to 'module/Unzip.py')
-rw-r--r-- | module/Unzip.py | 50 |
1 files changed, 50 insertions, 0 deletions
diff --git a/module/Unzip.py b/module/Unzip.py new file mode 100644 index 000000000..f56fbe751 --- /dev/null +++ b/module/Unzip.py @@ -0,0 +1,50 @@ +import zipfile +import os + +class Unzip: + def __init__(self): + pass + + def extract(self, file, dir): + if not dir.endswith(':') and not os.path.exists(dir): + os.mkdir(dir) + + zf = zipfile.ZipFile(file) + + # create directory structure to house files + self._createstructure(file, dir) + + # extract files to directory structure + for i, name in enumerate(zf.namelist()): + + if not name.endswith('/') and not name.endswith("config"): + print "extracting", name.replace("pyload/","") + outfile = open(os.path.join(dir, name.replace("pyload/","")), 'wb') + outfile.write(zf.read(name)) + outfile.flush() + outfile.close() + + def _createstructure(self, file, dir): + self._makedirs(self._listdirs(file), dir) + + def _makedirs(self, directories, basedir): + """ Create any directories that don't currently exist """ + for dir in directories: + curdir = os.path.join(basedir, dir) + if not os.path.exists(curdir): + os.mkdir(curdir) + + def _listdirs(self, file): + """ Grabs all the directories in the zip structure + This is necessary to create the structure before trying + to extract the file to it. """ + zf = zipfile.ZipFile(file) + + dirs = [] + + for name in zf.namelist(): + if name.endswith('/'): + dirs.append(name.replace("pyload/","")) + + dirs.sort() + return dirs |