Node.js文件编码格式的转换的方法


Posted in Javascript onApril 27, 2018

项目很多 lua 文件不是 utf-8格式,使用 EditPlus 查看的时候,显示为ASCII。还有的是带BOM的,带BOM倒好处理,之前写过,有一定规律。

ASCII编码就比较蛋疼,通过搜索网上资源,反复测试对比,最终形成下面比较靠谱的方法(有一些 EditPlus显示编码为utf-8但node.js库返回的却是其它编码>_<)

判断修改是否无误,只需要在修改完之后,通过SVN提交,浏览提交列表,双击任意一项待提交文件,如果显示下图所示的对话框,则说明修改成功,其它都会看到中文反而变成乱码了

Node.js文件编码格式的转换的方法

var fs = require('fs');
var chardet = require('chardet');
var jschardet = require("jschardet");
var encoding = require("encoding");

var path = "lua目录";

function readDirectory(dirPath) {
  if (fs.existsSync(dirPath)) {
    var files = fs.readdirSync(dirPath);

    files.forEach(function (file) {
      var filePath = dirPath + "/" + file;
      var stats = fs.statSync(filePath);

      if (stats.isDirectory()) {
        // console.log('/n读取目录:\n', filePath, "\n");
        readDirectory(filePath);
      } else if (stats.isFile() && /\.lua$/.test(filePath)) {
        var buff = fs.readFileSync(filePath);
        if (buff.length && buff[0].toString(16).toLowerCase() == "ef" && buff[1].toString(16).toLowerCase() == "bb" && buff[2].toString(16).toLowerCase() == "bf") {
          //EF BB BF 239 187 191
          console.log('\n发现BOM文件:', filePath, "\n");

          buff = buff.slice(3);
          fs.writeFile(filePath, buff.toString(), "utf8");
        }

        // { encoding: 'UTF-8', confidence: 0.99 }
        // var charset = chardet.detectFileSync(filePath);
        var info = jschardet.detect(buff);

        if (info.encoding == "GB2312" || info.encoding == "ascii") {
          var resultBuffer = encoding.convert(buff, "UTF-8", info.encoding);
          fs.writeFile(filePath, resultBuffer, "utf8");
        }
        else if (info.encoding != "UTF-8" && chardet.detectFileSync(filePath) != "UTF-8")
        {
          if (buff.toString().indexOf("\r\n") > -1)
          {
            var resultBuffer = encoding.convert(buff, "UTF-8", "GBK");
            fs.writeFile(filePath, resultBuffer, "utf8");
          }
        }
      }
    });

  } else {
    console.log('Not Found Path : ', dirPath);
  }
}

readDirectory(path);

注意上面的判断,第一个明确是 GB2312或者ascii时,直接将相应的编码转为 utf-8。而如果返回是格式,先判断是否有PC下的换行符,如果有则全部将它视为GBK进行处理。

整个思路其实是比较简单,难点在于如果判断文件编码格式。这个真的很难>_<,获取原编码格式后,调用 encoding.convert(buff, 目标编码格式 , 原始编码格式 ); 便可得到所需要的编码。如果有空而且有兴趣,可以下载Notepad++的源码,看它是如何判断文件的编码格式

注:上面的方法所修改的文件,跟 Mac 上需要提交的文件列表是一致的,至少能解决我目前遇到的问题。如果有特殊的,可对上面的代码进行修正。

用到的第三方库:

encoding https://github.com/andris9/encoding
jschardet https://github.com/aadsm/jschardet
node-chardet https://github.com/runk/node-chardet

编码相关的基础知识,可以参考这篇文章: https://3water.com/article/31045.htm

维基百科和其它资料太过专业化了,而且对 ASCII 编码的介绍不多,不再一一列举出来了

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
Prototype 学习 工具函数学习($A方法)
Jul 12 Javascript
JS实现图片延迟加载并淡入淡出效果的简单方法
Aug 25 Javascript
利用BootStrap弹出二级对话框的简单实现方法
Sep 21 Javascript
vue实现百度搜索下拉提示功能实例
Jun 14 Javascript
vue.js select下拉框绑定和取值方法
Mar 03 Javascript
Nuxt配合Node在实际生产中的应用详解
Aug 07 Javascript
vuex 解决报错this.$store.commit is not a function的方法
Dec 17 Javascript
通过JavaScript下载文件到本地的方法(单文件)
Mar 17 Javascript
小程序数据通信方法大全(推荐)
Apr 15 Javascript
微信小程序Page中data数据操作和函数调用方法
May 08 Javascript
vue tab滚动到一定高度,固定在顶部,点击tab切换不同的内容操作
Jul 22 Javascript
JavaScript实现图片合成下载的示例
Nov 19 Javascript
jQuery实现鼠标滑过商品小图片上显示对应大图片功能【测试可用】
Apr 27 #jQuery
基于Vue实现拖拽效果
Apr 27 #Javascript
Node.js利用console输出日志文件的方法示例
Apr 27 #Javascript
vue拦截器实现统一token,并兼容IE9验证功能
Apr 26 #Javascript
使用Vue动态生成form表单的实例代码
Apr 26 #Javascript
Javascript的console['']常用输入方法汇总
Apr 26 #Javascript
r.js来合并压缩css文件的示例
Apr 26 #Javascript
You might like
《忧国的莫里亚蒂》先导宣传图与STAFF公开
2020/03/04 日漫
初学者入门:细述PHP4的核心Zend
2006/09/05 PHP
新浪新闻小偷
2006/10/09 PHP
php发送post请求函数分享
2014/03/06 PHP
php生成html文件方法总结
2014/12/01 PHP
PHP使用数组依次替换字符串中匹配项
2016/01/08 PHP
PHP微信红包生成代码分享
2016/10/06 PHP
PHP常见过waf webshell以及最简单的检测方法
2019/05/21 PHP
Laravel 解决composer相关操作提示php相关异常的问题
2019/10/23 PHP
JavaScript 函数式编程的原理
2009/10/16 Javascript
关于Aptana Studio生成自动备份文件的解决办法
2009/12/23 Javascript
鼠标滚轴控制文本框值的JS代码
2013/11/19 Javascript
jquery.serialize() 函数语法及简单实例
2016/07/08 Javascript
JS回调函数简单用法示例
2017/02/09 Javascript
探索JavaScript中私有成员的相关知识
2019/06/13 Javascript
Antd的table组件表格的序号自增操作
2020/10/27 Javascript
[07:57]DOTA2热力大趴狂欢夜 广州站活动回顾
2013/11/27 DOTA
[45:06]完美世界DOTA2联赛PWL S2 Magma vs InkIce 第二场 11.28
2020/12/02 DOTA
查看Python安装路径以及安装包路径小技巧
2015/04/28 Python
Python continue继续循环用法总结
2018/06/10 Python
python 多进程队列数据处理详解
2019/12/23 Python
用canvas画心电图的示例代码
2018/09/10 HTML / CSS
计算机应用专业学生的自我评价分享
2013/11/03 职场文书
保安员岗位职责
2013/11/17 职场文书
个性大学生自我评价
2013/12/04 职场文书
制药工程专业职业生涯规划范文
2014/03/10 职场文书
指导教师评语
2014/04/26 职场文书
国旗下的演讲稿
2014/05/08 职场文书
党支部换届选举方案
2014/05/08 职场文书
2014年青年教师工作总结
2014/12/17 职场文书
旷课检讨书范文
2015/01/27 职场文书
2015年学生会个人工作总结
2015/04/09 职场文书
幼儿园教师师德师风承诺书
2015/04/28 职场文书
工资证明格式模板
2015/06/12 职场文书
《打电话》教学反思
2016/02/22 职场文书
vue-cli3.x配置全局的scss的时候报错问题及解决
2022/04/30 Vue.js