0

有没有办法对文件夹进行 tar 并获取 tar 流而不是 tar 文件?我曾尝试使用 tar 模块,但它直接返回 tarred 文件。

with tarfile.open("zipped.tar",'w|') as tar:
    for base_root, subFolders, files in os.walk('test'):
            for j in files:
                filepath = os.path.join(base_root,j)
                if os.path.isfile(filepath):
                    with open(filepath, 'rb') as file:
                        size = os.stat(filepath).st_size
                        info = tarfile.TarInfo()
                        info.size = size
                        info.name = filepath
                        if(size <= chunck_size):
                            data = file.read(info.size)
                            fobj = StringIO.StringIO(data)
                            tar.addfile(info, fobj)
                        else:
                            data = ""
                            while True:
                                temp_data = file.read(chunck_size)
                                if temp_data == '':
                                    break
                                data = data + temp_data
                            fobj = StringIO.StringIO(data)
                            tar.addfile(info, fobj) 
4

1 回答 1

1

根据文档open可以采取一个fileobj论点:

如果指定了 fileobj,它将用作以二进制模式打开的文件对象的替代名称。它应该在位置 0。

所以你可以写这个,然后使用缓冲区对象。

import io
buffer = io.BytesIO()
with tarfile.open("zipped.tar",'w|', fileobj=buffer) as tar:
于 2012-11-26T11:36:28.393 回答