diff options
author | 2015-04-07 22:22:18 +0200 | |
---|---|---|
committer | 2015-04-07 22:22:18 +0200 | |
commit | d2fe85670726901da627490da4155af972c1a62e (patch) | |
tree | b8931d070a51b6d8b1dabe881f54504f9d9ef6de /lib/Unzip.py | |
parent | Update user-agent (diff) | |
parent | fix gui (diff) | |
download | pyload-d2fe85670726901da627490da4155af972c1a62e.tar.xz |
Merge branch 'pr/n1_ardi69' into 0.4.10
Diffstat (limited to 'lib/Unzip.py')
-rw-r--r-- | lib/Unzip.py | 50 |
1 files changed, 50 insertions, 0 deletions
diff --git a/lib/Unzip.py b/lib/Unzip.py new file mode 100644 index 000000000..f56fbe751 --- /dev/null +++ b/lib/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 |