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

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

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

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

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 上需要提交的文件列表是一致的,至少能解决我目前遇到的问题。如果有特殊的,可对上面的代码进行修正。

用到的第三方库:

编码相关的基础知识,可以参考阮一峰的这篇文章:http://www.ruanyifeng.com/blog/2007/10/ascii_unicode_and_utf-8.html

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

原文地址:https://www.cnblogs.com/meteoric_cry/p/8952848.html

时间: 2024-10-18 12:20:21

Node.js文件编码格式的转换的相关文章

Node.JS 文件读写,把Sheet图集转换为龙骨动画图集

Node.JS 文件读写,把Sheet图集数据转换为龙骨动画图集数据 var fs = require("fs") var readline = require("readline"); var rl = readline.createInterface({ input:process.stdin, output:process.stdout }); var path = undefined; var dbName = undefined; rl.question(

Node.js文件模块fs监视文件变化

Node.js文件模块fs监视文件变化 Node中文件模块fs监视文件的函数源码如下: fs.watch = function(filename) { nullCheck(filename); var watcher; var options; var listener; if (util.isObject(arguments[1])) { options = arguments[1]; listener = arguments[2]; } else { options = {}; listen

node.js 文件路径及环境问题

node.js 安装在安装时提供的根目录下 npm 安装的全局包 在  用户/用户名/AppData/Roaming/npm/node-modules下 npm 安装的本地文件在命令行根目录下 关于在node中创建项目 有两种方法 1  通过express 首先安装express框架: $ npm install -g express-generator 创建项目(创建的项目位于命令行根目录下): express helloworld 2 通过 mkdir nodetext && cd n

Node.js文件上传

Node.js express使用Multer实现文件上传html部分 <div> <h3>文件上传:</h3> 选择一个文件上传: <br/> <form action="/upload" method="post" enctype="multipart/form-data"> <input type="file" name="content&quo

Linux 如何查看文件编码格式及转换文件编码

常常在Linux中操作windows下的文件时,会遇到乱码的情形.常见的比如在Visual Studio 中写的C\C++程序需要放到Linux主机上编译,而程序的中文注释则显示为乱码,比较严重的是由于编码原因,linux上的编译器报错.这是由于Windows中默认的文件格式是GBK(gb2312),而Linux一般都是UTF-8.那么如何在Linux中如何查看文件的编码及如何进行对文件进行编码转换呢? 用VIM查看文件编码 在Vim 中可以直接查看文件编码 :set fileencoding即

在window执行node.js文件查询数据库

node.js代码: var mysql = require('mysql'); var connection = mysql.createConnection({ host : 'localhost',//本机数据库使用localhost user : 'root',//用户名 password : '23191306',//密码 port: '3306',//端口号(默认3306) database: 'study_sql'//数据库名称 }); connection.connect();

Node.js 文件操作

新建一个文件a.txt,并写入"你好,这是一个新文件.". 代码 demo1.js var fs = require('fs'); console.log(1); //创建文件并写入内容 fs.writeFile('e:/nodeTest/a.txt','这是一个新文件.',function(err) { if(err){ console.log('不好意思,文件写入失败了'); } console.log(2); }); console.log(3); 进入 E:\nodeTest\

Node JS文件操作fs

文件操作readFile是异步的,readFileAync是同步的 var fs=require('fs'); //异步读取文件fs.readFile('sum.js','utf-8',function(err,data){ if(err){ console.log(err);} else { console.log(data);//上面没有设置'utf-8'格式就会输出一个二进制的buffter}}); //同步读取文件var data = fs.readFileAync('log.txt',

Node.js 文件夹目录结构创建

第一次接触NodeJS的文件系统就被它的异步的响应给搞晕了,后来发现NodeJS判断文件夹是否存在和创建文件夹是还有同步方法的,但是还是想尝试使用异步的方法去实现. 使用的方法:fs.exists(path, callback);fs.mkdir(path, [mode], callback); 实现文件夹目录结构的创建代码实现如下: //创建文件夹 function mkdir(pos, dirArray,_callback){ var len = dirArray.length; conso