這篇文章將為大家詳細(xì)講解有關(guān)利用Node.js進(jìn)行文件編碼格式轉(zhuǎn)換的方法,小編覺(jué)得挺實(shí)用的,因此分享給大家做個(gè)參考,希望大家閱讀完這篇文章后可以有所收獲。
創(chuàng)新互聯(lián)網(wǎng)絡(luò)公司擁有十年的成都網(wǎng)站開(kāi)發(fā)建設(shè)經(jīng)驗(yàn),數(shù)千家客戶(hù)的共同信賴(lài)。提供網(wǎng)站建設(shè)、成都網(wǎng)站建設(shè)、網(wǎng)站開(kāi)發(fā)、網(wǎng)站定制、外鏈、建網(wǎng)站、網(wǎng)站搭建、成都響應(yīng)式網(wǎng)站建設(shè)公司、網(wǎng)頁(yè)設(shè)計(jì)師打造企業(yè)風(fēng)格,提供周到的售前咨詢(xún)和貼心的售后服務(wù)
ASCII編碼就比較蛋疼,通過(guò)搜索網(wǎng)上資源,反復(fù)測(cè)試對(duì)比,最終形成下面比較靠譜的方法(有一些 EditPlus顯示編碼為utf-8但node.js庫(kù)返回的卻是其它編碼>_<)
判斷修改是否無(wú)誤,只需要在修改完之后,通過(guò)SVN提交,瀏覽提交列表,雙擊任意一項(xiàng)待提交文件,如果顯示下圖所示的對(duì)話(huà)框,則說(shuō)明修改成功,其它都會(huì)看到中文反而變成亂碼了
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發(fā)現(xià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);
注意上面的判斷,第一個(gè)明確是 GB2312或者ascii時(shí),直接將相應(yīng)的編碼轉(zhuǎn)為 utf-8。而如果返回是格式,先判斷是否有PC下的換行符,如果有則全部將它視為GBK進(jìn)行處理。
整個(gè)思路其實(shí)是比較簡(jiǎn)單,難點(diǎn)在于如果判斷文件編碼格式。這個(gè)真的很難>_<,獲取原編碼格式后,調(diào)用 encoding.convert(buff, 目標(biāo)編碼格式 , 原始編碼格式 ); 便可得到所需要的編碼。如果有空而且有興趣,可以下載Notepad++的源碼,看它是如何判斷文件的編碼格式
關(guān)于“利用Node.js進(jìn)行文件編碼格式轉(zhuǎn)換的方法”這篇文章就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,使各位可以學(xué)到更多知識(shí),如果覺(jué)得文章不錯(cuò),請(qǐng)把它分享出去讓更多的人看到。