本文整理匯總了Python中lzma.FORMAT_RAW屬性的典型用法代碼示例。如果您正苦於以下問題:Python lzma.FORMAT_RAW屬性的具體用法?Python lzma.FORMAT_RAW怎麽用?Python lzma.FORMAT_RAW使用的例子?那麽, 這裏精選的屬性代碼示例或許可以為您提供幫助。您也可以進一步了解該屬性所在類lzma
的用法示例。
在下文中一共展示了lzma.FORMAT_RAW屬性的13個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。
示例1: CompressLZMA
# 需要導入模塊: import lzma [as 別名]
# 或者: from lzma import FORMAT_RAW [as 別名]
def CompressLZMA(string):
"""
CompressBrotli(string) -> str
Returns without delimiters the given string compressed \
using the lzstring compression method.
"""
compressed = lzma.compress(
string.encode("ascii"),
format=lzma.FORMAT_RAW,
filters=[{'id': lzma.FILTER_LZMA2, 'preset': 9 | lzma.PRESET_EXTREME}]
)
number = 1
for c in compressed:
number = number * 256 + c
result = ""
while number:
result = Codepage[number % 255] + result
number //= 255
return Codepage[LZMA_ENCODING] + result
示例2: DecompressLZMA
# 需要導入模塊: import lzma [as 別名]
# 或者: from lzma import FORMAT_RAW [as 別名]
def DecompressLZMA(string):
"""
DecompressBrotli(string) -> str
Returns the original form of the given string compressed \
using Google's brotli compression method., passed without delimiters.
"""
number = 0
for character in string:
ordinal = OrdinalLookup.get(character, ord(character))
number = number * 255 + ordinal - (ordinal > gap)
compressed = []
while number > 1:
compressed = [number % 256] + compressed
number //= 256
return lzma.decompress(
bytes(compressed),
format=lzma.FORMAT_RAW,
filters=[{'id': lzma.FILTER_LZMA2, 'preset': 9 | lzma.PRESET_EXTREME}]
).decode("ascii")
示例3: decompress
# 需要導入模塊: import lzma [as 別名]
# 或者: from lzma import FORMAT_RAW [as 別名]
def decompress(self, buf):
if not self.compressed:
return buf
ty = self.compression_type
if ty == CompressionType.LZMA:
props, dict_size = struct.unpack("<BI", buf.read(5))
lc = props % 9
props = int(props / 9)
pb = int(props / 5)
lp = props % 5
dec = lzma.LZMADecompressor(format=lzma.FORMAT_RAW, filters=[{
"id": lzma.FILTER_LZMA1,
"dict_size": dict_size,
"lc": lc,
"lp": lp,
"pb": pb,
}])
res = dec.decompress(buf.read())
return BytesIO(res)
if ty in (CompressionType.LZ4, CompressionType.LZ4HC):
res = lz4_decompress(buf.read(self.compressed_size), self.uncompressed_size)
return BytesIO(res)
raise NotImplementedError("Unimplemented compression method: %r" % (ty))
示例4: _lzma
# 需要導入模塊: import lzma [as 別名]
# 或者: from lzma import FORMAT_RAW [as 別名]
def _lzma(f, size):
import lzma
data = f.read()
props = lzma._decode_filter_properties(lzma.FILTER_LZMA1, data[0:5])
return lzma.decompress(data[5:], lzma.FORMAT_RAW, filters=[props])
示例5: init_compressions
# 需要導入模塊: import lzma [as 別名]
# 或者: from lzma import FORMAT_RAW [as 別名]
def init_compressions():
ident = lambda x: x
compressions = {'': Compression(ident, ident)}
for name in ('bz2', 'zlib'):
try:
m = __import__(name)
except ImportError:
warnings.warn('%s is not available' % name)
else:
compressions[name] = Compression(
lambda x: m.compress(x, 9), m.decompress)
try:
import lzma
except ImportError:
warnings.warn('lzma is not available')
else:
filters = [{'id': lzma.FILTER_LZMA2}]
compress = lambda s: lzma.compress(s,
format=lzma.FORMAT_RAW,
filters=filters)
decompress = lambda s: lzma.decompress(s,
format=lzma.FORMAT_RAW,
filters=filters)
compressions['lzma2'] = Compression(compress, decompress)
return compressions
示例6: write_masks_to_zarr
# 需要導入模塊: import lzma [as 別名]
# 或者: from lzma import FORMAT_RAW [as 別名]
def write_masks_to_zarr(ds_mask, output_path):
import lzma
lzma_filters = [dict(id=lzma.FILTER_DELTA, dist=1),
dict(id=lzma.FILTER_LZMA2, preset=1)]
from numcodecs import LZMA
compressor = LZMA(filters=lzma_filters, format=lzma.FORMAT_RAW)
encoding = {vname: {'compressor': compressor} for vname in ds_mask.data_vars}
return ds_mask.to_zarr(output_path, encoding=encoding)
示例7: get_lzma_decompressor
# 需要導入模塊: import lzma [as 別名]
# 或者: from lzma import FORMAT_RAW [as 別名]
def get_lzma_decompressor(coders: List[Dict[str, Any]]):
filters = [] # type: List[Dict[str, Any]]
for coder in coders:
if coder['numinstreams'] != 1 or coder['numoutstreams'] != 1:
raise UnsupportedCompressionMethodError('Only a simple compression method is currently supported.')
if not SupportedMethods.is_native_coder(coder):
raise UnsupportedCompressionMethodError
properties = coder.get('properties', None)
filter_id = SupportedMethods.get_filter_id(coder)
if properties is not None:
filters[:0] = [lzma._decode_filter_properties(filter_id, properties)] # type: ignore
else:
filters[:0] = [{'id': filter_id}]
return lzma.LZMADecompressor(format=lzma.FORMAT_RAW, filters=filters)
示例8: _set_native_compressors_coders
# 需要導入模塊: import lzma [as 別名]
# 或者: from lzma import FORMAT_RAW [as 別名]
def _set_native_compressors_coders(self, filters):
self.cchain.add_filter(lzma.LZMACompressor(format=lzma.FORMAT_RAW, filters=filters))
for filter in filters:
self.coders.insert(0, SupportedMethods.get_coder(filter))
示例9: test_lzma_raw_decompressor_lzmabcj
# 需要導入模塊: import lzma [as 別名]
# 或者: from lzma import FORMAT_RAW [as 別名]
def test_lzma_raw_decompressor_lzmabcj():
# two files are compress same source by different methods
indata = []
with testdata_path.joinpath('lzma_bcj_1.7z').open('rb') as rawin:
rawin.seek(32)
indata.append(rawin.read(11327))
with testdata_path.joinpath('lzma_bcj_2.7z').open('rb') as rawin:
rawin.seek(32)
indata.append(rawin.read(11334))
filters1 = []
filters1.append({'id': lzma.FILTER_X86})
filters1.append(lzma._decode_filter_properties(lzma.FILTER_LZMA1, b']\x00\x00\x01\x00'))
filters2 = []
filters2.append({'id': lzma.FILTER_X86})
filters2.append(lzma._decode_filter_properties(lzma.FILTER_LZMA2, b'\x0b'))
decompressor1 = lzma.LZMADecompressor(format=lzma.FORMAT_RAW, filters=filters1)
lzmabcj_out = decompressor1.decompress(indata[0])
decompressor3 = lzma.LZMADecompressor(format=lzma.FORMAT_RAW, filters=filters2)
lzma2bcj_out = decompressor3.decompress(indata[1])
decompressor4 = lzma.LZMADecompressor(format=lzma.FORMAT_RAW, filters=filters1[1:])
lzma_out = decompressor4.decompress(indata[0])
decompressor5 = lzma.LZMADecompressor(format=lzma.FORMAT_RAW, filters=filters2[1:])
lzma2_out = decompressor5.decompress(indata[1])
#
# filters1 pipeline: indata[0] --> LZMA1 --> FILTER_X86 --> lzmabcj_out
# +----> lzma_out
# filters2 pipeline: indata[1] --> LZMA2 --> FILTER_X86 --> lzma2bcj_out
# +----> lzma2_out
#
# lzma_out and lzma2_out are same.
#
# lzmabcj_out and lzma2bcj_out should be same
# but lzmabcj_out lacks last 4 bytes by python lzma/liblzma bug.
#
uncompress_size = 12800
assert lzma_out == lzma2_out
assert len(lzma2bcj_out) == uncompress_size
assert len(lzmabcj_out) == uncompress_size
示例10: test_lzma_lzma2_compressor
# 需要導入模塊: import lzma [as 別名]
# 或者: from lzma import FORMAT_RAW [as 別名]
def test_lzma_lzma2_compressor():
filters = [{'id': 33, 'dict_size': 16777216}]
assert lzma.LZMADecompressor(format=lzma.FORMAT_RAW, filters=filters) is not None
示例11: test_lzma_lzma2bcj_compressor
# 需要導入模塊: import lzma [as 別名]
# 或者: from lzma import FORMAT_RAW [as 別名]
def test_lzma_lzma2bcj_compressor():
filters = [{'id': 4}, {'id': 33, 'dict_size': 16777216}]
assert lzma.LZMADecompressor(format=lzma.FORMAT_RAW, filters=filters) is not None
示例12: test_lzmadecompressor_lzmabcj
# 需要導入模塊: import lzma [as 別名]
# 或者: from lzma import FORMAT_RAW [as 別名]
def test_lzmadecompressor_lzmabcj():
indata = b'This file is located in the root.'
compressor = lzma.LZMACompressor(format=lzma.FORMAT_RAW,
filters=[{'id': lzma.FILTER_X86}, {'id': lzma.FILTER_LZMA1}])
compressed = compressor.compress(indata)
compressed += compressor.flush()
decompressor = lzma.LZMADecompressor(format=lzma.FORMAT_RAW,
filters=[{'id': lzma.FILTER_X86}, {'id': lzma.FILTER_LZMA1}])
outdata = decompressor.decompress(data=compressed)
assert outdata == indata
示例13: _init
# 需要導入模塊: import lzma [as 別名]
# 或者: from lzma import FORMAT_RAW [as 別名]
def _init(self):
props = lzma._encode_filter_properties(self.compress_options)
self._comp = lzma.LZMACompressor(
lzma.FORMAT_RAW,
filters=(
lzma._decode_filter_properties(self.compress_options["id"], props),))
return struct.pack("<BBH", 9, 4, len(props)) + props