python解決js文件utf-8編碼亂碼問題(推薦)
更新時間:2018年05月02日 11:28:18 作者:雨夜星辰03
這篇文章主要介紹了python解決js文件utf-8編碼亂碼問題,非常不錯,具有參考借鑒價值,需要的朋友可以參考下
html文件中引入js文件,顯示亂碼!
js文件為utf-8 編碼(無bom) ,此時只要將js文件轉成utf-8 BOM編碼就可以解決了
可以使用notepad++轉碼
也可以使用下面的python代碼批量轉碼
# -*- coding:utf-8 -*-
import os,sys
import chardet
def convert( filename, in_enc = "GBK", out_enc="UTF-8" ):
try:
print("convert " + filename)
f = open(filename,'rb')
content = f.read()
result = chardet.detect(content)#通過chardet.detect獲取當前文件的編碼格式串,返回類型為字典類型
print(result)
f.close()
coding = result.get('encoding')#獲取encoding的值[編碼格式]
if coding != 'UTF-8-SIG' and coding == 'utf-8':#文件格式如果是utf-8的時候,才進行轉碼
print(coding + " to "+ out_enc +"!")
new_content = content.decode(in_enc).encode(out_enc)
f = open(filename, 'wb')
f.write(new_content)
f.close()
print(" done")
else:
print(coding)
except IOError as e:
# except:
print(e)
def explore(dir):
for root, dirs, files in os.walk(dir):
for file in files:
path = os.path.join(root, file)
convert(path)
def main(dir):
if(os.path.isdir(dir)):
fpaths = [fpath for fpath in os.listdir(dir) if os.path.isfile(dir+"\\"+fpath) and fpath.endswith('.js')]
dpaths = [dpath for dpath in os.listdir(dir) if os.path.isdir(dir+"\\"+dpath)]
for f in fpaths:
convert(dir+"\\"+f,'utf-8','UTF-8-SIG')
for d in dpaths:
print(d)
main(dir+"\\"+d)
if __name__ == "__main__":
main('目錄')
總結
以上所述是小編給大家介紹的python解決js文件utf-8編碼亂碼問題,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對腳本之家網站的支持!
相關文章
VSCode配置python環(huán)境及中文問題解決方法
這篇文章主要介紹了VSCode配置python環(huán)境及中文問題,print打印中文亂碼如何解決這個問題呢,本文給大家?guī)韮煞N方法幫助大家解決這個問題,需要的朋友可以參考下2022-02-02
解決Keras 與 Tensorflow 版本之間的兼容性問題
今天小編就為大家分享一篇解決Keras 與 Tensorflow 版本之間的兼容性問題,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-02-02

