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で復号します.