我想使用PyLZMA从归档文件(例如test.7z)中提取一个文件,然后将其提取到相同的目录中。
我是Python的新手,不知道如何开始。我做了一些谷歌搜索,找到了some examples和docs,但我不明白它们是如何工作的。
有没有人可以把我想要做的事情的基本代码贴出来,这样我就可以开始工作和理解了?
发布于 2012-09-06 11:32:17
下面是一个处理基本功能的Python类。我已经将它用于我自己的工作:
import py7zlib
class SevenZFile(object):
@classmethod
def is_7zfile(cls, filepath):
'''
Class method: determine if file path points to a valid 7z archive.
'''
is7z = False
fp = None
try:
fp = open(filepath, 'rb')
archive = py7zlib.Archive7z(fp)
n = len(archive.getnames())
is7z = True
finally:
if fp:
fp.close()
return is7z
def __init__(self, filepath):
fp = open(filepath, 'rb')
self.archive = py7zlib.Archive7z(fp)
def extractall(self, path):
for name in self.archive.getnames():
outfilename = os.path.join(path, name)
outdir = os.path.dirname(outfilename)
if not os.path.exists(outdir):
os.makedirs(outdir)
outfile = open(outfilename, 'wb')
outfile.write(self.archive.getmember(name).read())
outfile.close()发布于 2012-06-01 07:01:46
下面是我在http://www.linuxplanet.org/blogs/?cat=3845找到的两个代码片段
# Compress the input file (as a stream) to a file (as a stream)
i = open(source_file, 'rb')
o = open(compressed_file, 'wb')
i.seek(0)
s = pylzma.compressfile(i)
while True:
tmp = s.read(1)
if not tmp: break
o.write(tmp)
o.close()
i.close()
# Decomrpess the file (as a stream) to a file (as a stream)
i = open(compressed_file, 'rb')
o = open(decompressed_file, 'wb')
s = pylzma.decompressobj()
while True:
tmp = i.read(1)
if not tmp: break
o.write(s.decompress(tmp))
o.close()
i.close()https://stackoverflow.com/questions/10701528
复制相似问题