为了账号安全,请及时绑定邮箱和手机立即绑定

有时候Node.js爬虫采集到的数据有少数汉字乱码,不知道怎么解决?

有时候Node.js爬虫采集到的数据有少数汉字乱码,不知道怎么解决?

正在回答

3 回答

乱码原因是传输数据时 buffer 的拼接问题!

例如以下写法:

var data = "";
res.on("data" , function(chunk){
    data += chunk;
});

如果爬取的数据的中文数据量比较小,一般显示是正常的。但当爬取的数据量较大时,很有可能出现部分汉字会乱码现象。

产生原因:
在默认的情况下 trunk 是一个 Buffer 对象,而

data += trunk

的实质上隐藏了 toString 的变换的:

data = data.toString() + trunk.toString();

由于汉字不是用一个字节来存储的,如果某一块 buffer 传输的恰好不完整,将会导致有被截破的汉字的存在,于是出现乱码。

解决方法:
先用一个数组把所有 buffer 保存起来,同时记录 buffer 的总长度。
数据传输完毕的时,再通过 Buffer.concat 方法把所有 buffer 拼接。
最后,用 toString 方法转成字符串,这时获取的 data 数据就是正确的了。

var chunks = [], size = 0;
res.on("data" , function(chunk){
    chunks.push(chunk);
    size += chunk.length;
});
res.on("end" , function(){
    var buffer = Buffer.concat(chunks, size);
    var html = buffer.toString();
});

// 在更细腻的 buffer 连接方式:

res.on('end', function () {
    var buffer = null;
    switch(buffers.length) {
        case 0:
            buffer = new Buffer(0);
            break;
        case 1:
            buffer = buffers[0];
            break;
        default:
            buffer = new Buffer(size);
            for (var i = 0, pos = 0, l = buffers.length; i < l; i++) {
                var chunk = buffers[i];
                chunk.copy(buffer, pos);
                pos += chunk.length;
            }
        break;
    }
    var html = buffer.toString();
});


1 回复 有任何疑惑可以回复我~

好像不是编码问题,如果是编码问题,每次爬去的中文应该全部是乱码。我的现象是连续爬取多次,只有其中某一的几个中文乱码。应该和数据流或缓冲有关系。

0 回复 有任何疑惑可以回复我~

var iconv = require('iconv-lite');

安装  iconv-lite

在获取Body之后转码

body = iconv.decode(body, 'gbk');




0 回复 有任何疑惑可以回复我~

举报

0/150
提交
取消
进击Node.js基础(二)
  • 参与学习       76755    人
  • 解答问题       226    个

本教程带你攻破 Nodejs,让 JavaScript流畅运行在服务器端

进入课程

有时候Node.js爬虫采集到的数据有少数汉字乱码,不知道怎么解决?

我要回答 关注问题
意见反馈 帮助中心 APP下载
官方微信