我一直在尋找在互聯網和無法找到PHP的LZW壓縮實現與這些JavaScript函數輸出的數據的工作原理:PHP LZW二進制解壓功能
function lzw_encode(s) {
var dict = {};
var data = (s + "").split("");
var out = [];
var currChar;
var phrase = data[0];
var code = 256;
for (var i=1; i<data.length; i++) {
currChar=data[i];
if (dict[phrase + currChar] != null) {
phrase += currChar;
}
else {
out.push(phrase.length > 1 ? dict[phrase] : phrase.charCodeAt(0));
dict[phrase + currChar] = code;
code++;
phrase=currChar;
}
}
out.push(phrase.length > 1 ? dict[phrase] : phrase.charCodeAt(0));
for (var i=0; i<out.length; i++) {
out[i] = String.fromCharCode(out[i]);
}
return out.join("");
}
function lzw_decode(s) {
var dict = {};
var data = (s + "").split("");
var currChar = data[0];
var oldPhrase = currChar;
var out = [currChar];
var code = 256;
var phrase;
debugger;
for (var i=1; i<data.length; i++) {
var currCode = data[i].charCodeAt(0);
if (currCode < 256) {
phrase = data[i];
}
else {
phrase = dict[currCode] ? dict[currCode] : (oldPhrase + currChar);
}
out.push(phrase);
currChar = phrase.charAt(0);
dict[code] = oldPhrase + currChar;
code++;
oldPhrase = phrase;
}
return out.join("");
}
我真的只需要一個PHP中的解壓縮算法,可以與上面的壓縮javascript函數一起使用。
上述lzw_encode功能編碼「這是壓縮函數的測試」作爲「這一測試ofĈhecomprĊsionfunctěn」
我發現的庫或者是越野車(HTTP://代碼.google.com/p/php-lzw /)或不輸入UTC字符。
任何幫助將不勝感激,
謝謝!
爲什麼不使用從JS [鏈接](http://rosettacode.org/wiki/LZW_compression#JavaScript)?在線上已經有了現成的PHP實現。例如:[link](http://webdevwonders.com/lzw-compression-and-decompression-with-javascript-and-php/)。 – BogdanM 2013-09-25 12:14:51
爲什麼i = 1在這裏:'for(var i = 1; i
BogdanM
2013-09-25 12:18:47