當前位置: 首頁>>代碼示例>>Python>>正文


Python zstandard.ZstdDecompressor方法代碼示例

本文整理匯總了Python中zstandard.ZstdDecompressor方法的典型用法代碼示例。如果您正苦於以下問題:Python zstandard.ZstdDecompressor方法的具體用法?Python zstandard.ZstdDecompressor怎麽用?Python zstandard.ZstdDecompressor使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在zstandard的用法示例。


在下文中一共展示了zstandard.ZstdDecompressor方法的14個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。

示例1: decompress

# 需要導入模塊: import zstandard [as 別名]
# 或者: from zstandard import ZstdDecompressor [as 別名]
def decompress(data, compressor_id):
    if compressor_id == SnappyContext.compressor_id:
        # python-snappy doesn't support the buffer interface.
        # https://github.com/andrix/python-snappy/issues/65
        # This only matters when data is a memoryview since
        # id(bytes(data)) == id(data) when data is a bytes.
        # NOTE: bytes(memoryview) returns the memoryview repr
        # in Python 2.7. The right thing to do in 2.7 is call
        # memoryview.tobytes(), but we currently only use
        # memoryview in Python 3.x.
        return snappy.uncompress(bytes(data))
    elif compressor_id == ZlibContext.compressor_id:
        return zlib.decompress(data)
    elif compressor_id == ZstdContext.compressor_id:
        # ZstdDecompressor is not thread safe.
        # TODO: Use a pool?
        return ZstdDecompressor().decompress(data)
    else:
        raise ValueError("Unknown compressorId %d" % (compressor_id,)) 
開發者ID:wistbean,項目名稱:learn_python3_spider,代碼行數:21,代碼來源:compression_support.py

示例2: _read_rel_zs_rows

# 需要導入模塊: import zstandard [as 別名]
# 或者: from zstandard import ZstdDecompressor [as 別名]
def _read_rel_zs_rows(filepath, chunk_size=8 * 1000 * 1000):
    from zstandard import ZstdDecompressor

    with open(filepath, "rb") as fh:
        ctx = ZstdDecompressor()
        with ctx.stream_reader(fh) as reader:
            over = False
            chunks = []
            rows = []
            while not over:
                have_row = False
                while not have_row:
                    chunk = reader.read(chunk_size)
                    if not chunk:
                        over = True
                        break
                    if b"\n" in chunk:
                        have_row = True
                    chunks.append(chunk)
                (new_rows, semi_row) = _consume_rows(chunks)
                rows += new_rows
                chunks = [semi_row]
    return rows 
開發者ID:limix,項目名稱:pandas-plink,代碼行數:25,代碼來源:_read_rel.py

示例3: open_tar_zst

# 需要導入模塊: import zstandard [as 別名]
# 或者: from zstandard import ZstdDecompressor [as 別名]
def open_tar_zst(path, mode):
    if mode == "w":
        cctx = zstandard.ZstdCompressor(threads=-1)
        with open(path, "wb") as f:
            with cctx.stream_writer(f) as compressor:
                with tarfile.open(mode="w|", fileobj=compressor) as tar:
                    yield tar
    elif mode == "r":
        dctx = zstandard.ZstdDecompressor()
        with open(path, "rb") as f:
            with dctx.stream_reader(f) as reader:
                with tarfile.open(mode="r|", fileobj=reader) as tar:
                    yield tar
    else:
        assert False, f"Unexpected mode: {mode}"


# Using tar directly is twice as fast than through Python! 
開發者ID:mozilla,項目名稱:bugbug,代碼行數:20,代碼來源:utils.py

示例4: data_file

# 需要導入模塊: import zstandard [as 別名]
# 或者: from zstandard import ZstdDecompressor [as 別名]
def data_file(self):
        """Return the uncompressed raw CPIO data of the RPM archive."""

        if self._data_file is None:
            fileobj = _SubFile(self._fileobj, self.data_offset)

            if self.headers["archive_compression"] == b"xz":
                if not getattr(sys.modules[__name__], "lzma", False):
                    raise NoLZMAModuleError("lzma module not present")
                self._data_file = lzma.LZMAFile(fileobj)
            elif self.headers["archive_compression"] == b"zstd":
                if not getattr(sys.modules[__name__], "zstandard", False):
                    raise NoZSTANDARDModuleError("zstandard module not present")
                if not (sys.version_info.major >= 3 and sys.version_info.minor >= 5):
                    raise NoBytesIOError("Need io.BytesIO (Python >= 3.5)")
                with zstandard.ZstdDecompressor().stream_reader(fileobj) as zstd_data:
                    self._data_file = io.BytesIO(zstd_data.read())
            else:
                self._data_file = gzip.GzipFile(fileobj=fileobj)

        return self._data_file 
開發者ID:srossross,項目名稱:rpmfile,代碼行數:23,代碼來源:__init__.py

示例5: decompress

# 需要導入模塊: import zstandard [as 別名]
# 或者: from zstandard import ZstdDecompressor [as 別名]
def decompress(self, source, cursor, compressedbytes, uncompressedbytes=None):
        if self.algo == uproot.const.kZLIB:
            from zlib import decompress as zlib_decompress
            return zlib_decompress(cursor.bytes(source, compressedbytes))

        elif self.algo == uproot.const.kLZMA:
            try:
                from lzma import decompress as lzma_decompress
            except ImportError:
                try:
                    from backports.lzma import decompress as lzma_decompress
                except ImportError:
                    raise ImportError("install lzma package with:\n    pip install backports.lzma\nor\n    conda install backports.lzma\n(or just use Python >= 3.3).")
            return lzma_decompress(cursor.bytes(source, compressedbytes))

        elif self.algo == uproot.const.kOldCompressionAlgo:
            raise NotImplementedError("ROOT's \"old\" algorithm (fCompress 300) is not supported")

        elif self.algo == uproot.const.kLZ4:
            try:
                from lz4.block import decompress as lz4_decompress
            except ImportError:
                raise ImportError("install lz4 package with:\n    pip install lz4\nor\n    conda install lz4")

            if uncompressedbytes is None:
                raise ValueError("lz4 needs to know the uncompressed number of bytes")
            return lz4_decompress(cursor.bytes(source, compressedbytes), uncompressed_size=uncompressedbytes)

        elif self.algo == uproot.const.kZSTD:
            try:
                import zstandard as zstd
            except ImportError:
                raise ImportError("install zstd package with:\n    pip install zstandard\nor\n    conda install zstandard")
            dctx = zstd.ZstdDecompressor()
            return dctx.decompress(cursor.bytes(source, compressedbytes))

        else:
            raise ValueError("unrecognized compression algorithm: {0}".format(self.algo)) 
開發者ID:scikit-hep,項目名稱:uproot,代碼行數:40,代碼來源:compressed.py

示例6: zstandard_file

# 需要導入模塊: import zstandard [as 別名]
# 或者: from zstandard import ZstdDecompressor [as 別名]
def zstandard_file(infile, mode="rb"):
        if "r" in mode:
            cctx = zstd.ZstdDecompressor()
            return cctx.stream_reader(infile)
        else:
            cctx = zstd.ZstdCompressor(level=10)
            return cctx.stream_writer(infile) 
開發者ID:intake,項目名稱:filesystem_spec,代碼行數:9,代碼來源:compression.py

示例7: test_zstandard

# 需要導入模塊: import zstandard [as 別名]
# 或者: from zstandard import ZstdDecompressor [as 別名]
def test_zstandard(self):
        data = self._data
        compress = verify_and_get_compress_func("zstandard")
        self.assertIsNotNone(compress)

        import zstandard

        decompressor = zstandard.ZstdDecompressor()

        self.assertEqual(data, decompressor.decompress(compress(data))) 
開發者ID:scalyr,項目名稱:scalyr-agent-2,代碼行數:12,代碼來源:util_test.py

示例8: zstd_decompress

# 需要導入模塊: import zstandard [as 別名]
# 或者: from zstandard import ZstdDecompressor [as 別名]
def zstd_decompress(path):
    dctx = zstandard.ZstdDecompressor()
    with open(f"{path}.zst", "rb") as input_f:
        with open(path, "wb") as output_f:
            dctx.copy_stream(input_f, output_f) 
開發者ID:mozilla,項目名稱:bugbug,代碼行數:7,代碼來源:utils.py

示例9: _db_open

# 需要導入模塊: import zstandard [as 別名]
# 或者: from zstandard import ZstdDecompressor [as 別名]
def _db_open(path, mode):
    parts = str(path).split(".")
    assert len(parts) > 1, "Extension needed to figure out serialization format"
    if len(parts) == 2:
        db_format = parts[-1]
        compression = None
    else:
        db_format = parts[-2]
        compression = parts[-1]

    assert compression is None or compression in COMPRESSION_FORMATS
    assert db_format in SERIALIZATION_FORMATS

    store_constructor = SERIALIZATION_FORMATS[db_format]

    if compression == "gz":
        with gzip.GzipFile(path, mode) as f:
            yield store_constructor(f)
    elif compression == "zstd":
        if "w" in mode or "a" in mode:
            cctx = zstandard.ZstdCompressor()
            with open(path, mode) as f:
                with cctx.stream_writer(f) as writer:
                    yield store_constructor(writer)
        else:
            dctx = zstandard.ZstdDecompressor()
            with open(path, mode) as f:
                with dctx.stream_reader(f) as reader:
                    yield store_constructor(reader)
    else:
        with open(path, mode) as f:
            yield store_constructor(f) 
開發者ID:mozilla,項目名稱:bugbug,代碼行數:34,代碼來源:db.py

示例10: _create_decompressor

# 需要導入模塊: import zstandard [as 別名]
# 或者: from zstandard import ZstdDecompressor [as 別名]
def _create_decompressor(self, alg):
        if alg == "snappy":
            return snappy.StreamDecompressor()
        elif alg == "lzma":
            return lzma.LZMADecompressor()
        elif alg == "zstd":
            return zstd.ZstdDecompressor().decompressobj()
        raise InvalidConfigurationError("invalid compression algorithm: {!r}".format(alg)) 
開發者ID:aiven,項目名稱:pghoard,代碼行數:10,代碼來源:compressor.py

示例11: __init__

# 需要導入模塊: import zstandard [as 別名]
# 或者: from zstandard import ZstdDecompressor [as 別名]
def __init__(self, next_fp):
        self._zstd = zstd.ZstdDecompressor().decompressobj()
        super().__init__(next_fp)
        self._done = False 
開發者ID:aiven,項目名稱:pghoard,代碼行數:6,代碼來源:zstdfile.py

示例12: download_report

# 需要導入模塊: import zstandard [as 別名]
# 或者: from zstandard import ZstdDecompressor [as 別名]
def download_report(self, report):
        """
        Download and extract a json+zstd covdir report
        """
        assert isinstance(report, Report)

        # Check the report is available on remote storage
        blob = self.bucket.blob(report.gcp_path)
        if not blob.exists():
            logger.debug("No report found on GCP", path=report.gcp_path)
            return False

        if os.path.exists(report.path):
            logger.info("Report already available", path=report.path)
            return True

        os.makedirs(os.path.dirname(report.archive_path), exist_ok=True)
        blob.download_to_filename(report.archive_path)
        logger.info("Downloaded report archive", path=report.archive_path)

        with open(report.path, "wb") as output:
            with open(report.archive_path, "rb") as archive:
                dctx = zstd.ZstdDecompressor()
                reader = dctx.stream_reader(archive)
                while True:
                    chunk = reader.read(16384)
                    if not chunk:
                        break
                    output.write(chunk)

        os.unlink(report.archive_path)
        logger.info("Decompressed report", path=report.path)
        return True 
開發者ID:mozilla,項目名稱:code-coverage,代碼行數:35,代碼來源:gcp.py

示例13: itkimage_from_json

# 需要導入模塊: import zstandard [as 別名]
# 或者: from zstandard import ZstdDecompressor [as 別名]
def itkimage_from_json(js, manager=None):
    """Deserialize a Javascript itk.js Image object."""
    if js is None:
        return None
    else:
        ImageType, dtype = _type_to_image(js['imageType'])
        decompressor = zstd.ZstdDecompressor()
        if six.PY2:
            asBytes = js['compressedData'].tobytes()
            pixelBufferArrayCompressed = np.frombuffer(asBytes, dtype=np.uint8)
        else:
            pixelBufferArrayCompressed = np.frombuffer(js['compressedData'],
                                                       dtype=np.uint8)
        pixelCount = reduce(lambda x, y: x * y, js['size'], 1)
        numberOfBytes = pixelCount * \
            js['imageType']['components'] * np.dtype(dtype).itemsize
        pixelBufferArray = \
            np.frombuffer(decompressor.decompress(pixelBufferArrayCompressed,
                                                  numberOfBytes),
                          dtype=dtype)
        pixelBufferArray.shape = js['size'][::-1]
        # Workaround for GetImageFromArray required until 5.0.1
        # and https://github.com/numpy/numpy/pull/11739
        pixelBufferArrayCopyToBeRemoved = pixelBufferArray.copy()
        # image = itk.PyBuffer[ImageType].GetImageFromArray(pixelBufferArray)
        image = itk.PyBuffer[ImageType].GetImageFromArray(
            pixelBufferArrayCopyToBeRemoved)
        Dimension = image.GetImageDimension()
        image.SetOrigin(js['origin'])
        image.SetSpacing(js['spacing'])
        direction = image.GetDirection()
        directionMatrix = direction.GetVnlMatrix()
        directionJs = js['direction']['data']
        for col in range(Dimension):
            for row in range(Dimension):
                directionMatrix.put(
                    row, col, directionJs[col + row * Dimension])
        return image 
開發者ID:InsightSoftwareConsortium,項目名稱:itkwidgets,代碼行數:40,代碼來源:trait_types.py

示例14: decompress_ncz

# 需要導入模塊: import zstandard [as 別名]
# 或者: from zstandard import ZstdDecompressor [as 別名]
def decompress_ncz(input,output):
	with open(input, 'rb') as f:
		header = f.read(0x4000)
		magic = readInt64(f)
		sectionCount = readInt64(f)
		sections = []
		for i in range(sectionCount):
			sections.append(Section(f))
			
		dctx = zstandard.ZstdDecompressor()
		reader = dctx.stream_reader(f)
			
		with open(output, 'wb+') as o:
			o.write(header)
			
			while True:
				chunk = reader.read(16384)
				
				if not chunk:
					break
					
				o.write(chunk)
				
			for s in sections:
				if s.cryptoType == 1: #plain text
					continue
					
				if s.cryptoType != 3:
					raise IOError('unknown crypto type')
					
				print('%x - %d bytes, type %d' % (s.offset, s.size, s.cryptoType))
				
				i = s.offset
				
				crypto = AESCTR(s.cryptoKey, s.cryptoCounter)
				end = s.offset + s.size
				
				while i < end:
					o.seek(i)
					crypto.seek(i)
					chunkSz = 0x10000 if end - i > 0x10000 else end - i
					buf = o.read(chunkSz)
					
					if not len(buf):
						break
					
					o.seek(i)
					o.write(crypto.encrypt(buf))
					
					i += chunkSz 
開發者ID:julesontheroad,項目名稱:NSC_BUILDER,代碼行數:52,代碼來源:decompressor.py


注:本文中的zstandard.ZstdDecompressor方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。