nodejsはcsv中国語の文字化けを読みます.
3699 ワード
いくつかのツールを作っている時に、nodejsがいくつかのcsvファイルの中の中国語を読み取ったら文字化けが発生します.ANSIを試してもだめです.生成する時はGBKコードであるべきだと予想していますが、nodejs原生はファイルを読みます.GBKはサポートされていません.じゃ、今は在庫を借ります.iconv-lite
// filePath
const stream = fs.createReadStream(filePath, { encoding: 'binary' });
let data = '';
stream.on('error', err => {
console.error(' ');
console.error(err);
});
stream.on('data', chunk => {
data += chunk;
});
stream.on('end', () => {
const buf = Buffer.from(data, 'binary');
const str = iconv.decode(buf, 'GBK'); // ,
});
注意読み込むときはバイナリ形式で読み、iconvでGBKで復号します.