Основная помощь по сжатию lzw в python - PullRequest
2 голосов
/ 26 июля 2011

Я просто пытаюсь написать действительно простой сценарий, который будет брать некоторый вводимый текст и сжимать его с помощью lzw, используя этот пакет: http://packages.python.org/lzw/

Я никогда раньше не пробовал кодировать с pythonи я полностью сбит с толку = (- Я также не могу найти в Интернете никакой документации об этом, кроме информации о пакете.

Вот что у меня есть:

import lzw

file = lzw.readbytes("collectemailinfo.txt", buffersize=1024)
enc = lzw.compress(file)
print enc

Любая помощь или указателиЛюбой вид будет высоко ценится!

Спасибо =)

1 Ответ

5 голосов
/ 26 июля 2011

Вот API пакета: http://packages.python.org/lzw/lzw-module.html

Здесь вы можете прочитать псевдо-код сжатия и декомпрессии здесь

Есть ли что-то еще, что вас смущает?

Вот пример:

Python

В этой версии данные содержат смешанные типизированные данные:

def compress(uncompressed):
    """Compress a string to a list of output symbols."""

    # Build the dictionary.
    dict_size = 256
    dictionary = dict((chr(i), chr(i)) for i in xrange(dict_size))
    # in Python 3: dictionary = {chr(i): chr(i) for i in range(dict_size)}

    w = ""
    result = []
    for c in uncompressed:
        wc = w + c
        if wc in dictionary:
            w = wc
        else:
            result.append(dictionary[w])
            # Add wc to the dictionary.
            dictionary[wc] = dict_size
            dict_size += 1
            w = c

    # Output the code for w.
    if w:
        result.append(dictionary[w])
    return result



def decompress(compressed):
    """Decompress a list of output ks to a string."""

    # Build the dictionary.
    dict_size = 256
    dictionary = dict((chr(i), chr(i)) for i in xrange(dict_size))
    # in Python 3: dictionary = {chr(i): chr(i) for i in range(dict_size)}

    w = result = compressed.pop(0)
    for k in compressed:
        if k in dictionary:
            entry = dictionary[k]
        elif k == dict_size:
            entry = w + w[0]
        else:
            raise ValueError('Bad compressed k: %s' % k)
        result += entry

        # Add w+entry[0] to the dictionary.
        dictionary[dict_size] = w + entry[0]
        dict_size += 1

        w = entry
    return result

Как использовать:

compressed = compress('TOBEORNOTTOBEORTOBEORNOT')
print (compressed)
decompressed = decompress(compressed)
print (decompressed)

выход

['T', 'O', 'B', 'E', 'O', 'R', 'N', 'O', 'T', 256, 258, 260, 265, 259, 261, 263]
TOBEORNOTTOBEORTOBEORNOT

ПРИМЕЧАНИЕ : этот пример взят из здесь

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...