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 相关文章推荐
JavaScript设置FieldSet展开与收缩
May 15 Javascript
js 多浏览器分别判断代码
Apr 01 Javascript
由JavaScript中call()方法引发的对面向对象继承机制call的思考
Sep 12 Javascript
javascript学习笔记(九) js对象 设计模式
Jun 19 Javascript
深入理解JavaScript系列(41):设计模式之模板方法详解
Mar 04 Javascript
浅谈JavaScript中变量和函数声明的提升
Aug 09 Javascript
JavaScript使用Ajax上传文件的示例代码
Aug 10 Javascript
详解Vue中watch的高级用法
May 02 Javascript
Node.js搭建WEB服务器的示例代码
Aug 15 Javascript
vue-router启用history模式下的开发及非根目录部署方法
Dec 23 Javascript
JavaScript解析机制与闭包原理实例详解
Mar 08 Javascript
JavaScript惰性载入函数实例分析
Mar 27 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
PHP实现的通过参数生成MYSQL语句类完整实例
2016/04/11 PHP
PHPExcel在linux环境下导出报500错误的解决方法
2017/01/26 PHP
Javascript 读书笔记索引贴
2010/01/11 Javascript
来自国外的页面JavaScript文件优化
2010/12/08 Javascript
JavaScript中函数声明优先于变量声明的实例分析
2012/03/01 Javascript
js动态修改input输入框的type属性(实现方法解析)
2013/11/13 Javascript
javascript计时器事件使用详解
2014/01/07 Javascript
jQuery提示插件alertify使用指南
2015/04/21 Javascript
浅谈JavaScript中的Math.atan()方法的使用
2015/06/14 Javascript
微信开发 微信授权详解
2016/10/21 Javascript
Angular.js中window.onload(),$(document).ready()的写法浅析
2017/09/28 Javascript
JavaScript累加、迭代、穷举、递归等常用算法实例小结
2018/05/08 Javascript
layui 监听表格复选框选中值的方法
2018/08/15 Javascript
Laravel admin实现消息提醒、播放音频功能
2019/07/10 Javascript
小程序使用wxs解决wxml保留2位小数问题
2019/12/13 Javascript
Python base64编码解码实例
2015/06/21 Python
Python 机器学习库 NumPy入门教程
2018/04/19 Python
python实现寻找最长回文子序列的方法
2018/06/02 Python
对Python中的条件判断、循环以及循环的终止方法详解
2019/02/08 Python
Django 1.10以上版本 url 配置注意事项详解
2019/08/05 Python
python实现广度优先搜索过程解析
2019/10/19 Python
tensorflow查看ckpt各节点名称实例
2020/01/21 Python
Windows 下更改 jupyterlab 默认启动位置的教程详解
2020/05/18 Python
日本最大的购物网站乐天市场国际版:Rakuten Global Market(支持中文)
2020/02/03 全球购物
精彩广告词大全
2014/03/19 职场文书
开学典礼主持词
2014/03/19 职场文书
教研处工作方案
2014/05/26 职场文书
啤酒节策划方案
2014/05/28 职场文书
法定授权委托证明书
2014/09/27 职场文书
2014年居委会工作总结
2014/12/09 职场文书
2015年电话销售工作总结范文
2015/04/20 职场文书
2015年世界环境日活动方案
2015/05/05 职场文书
2015年秋季开学典礼校长致辞
2015/07/16 职场文书
班委竞选稿范文
2015/11/21 职场文书
2016大一新生军训感言
2015/12/08 职场文书
聊聊pytorch测试的时候为何要加上model.eval()
2021/05/23 Python