批量文件编码转换用python实现的utf8转gb2312,vscode设置特殊文件的默认打开编码

本文主要是介绍批量文件编码转换用python实现的utf8转gb2312,vscode设置特殊文件的默认打开编码,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

批量文件编码转换用python实现的utf8转gb2312, 任意编码之间的相互转换都是可以的.改一下下面的参数即可

convert.py文件内容如下

import os
import glob
import chardet#检测文件编码类型
def detect_file_encoding(file_path):with open(file_path, 'rb') as f:data = f.read()result = chardet.detect(data)encoding = result['encoding']confidence = result['confidence']return encoding, confidencedef convert_encoding(file_path, from_encoding='utf-8', to_encoding='gb2312'):  """  将文件的编码从一种转换为另一种。  :param file_path: 文件的路径  :param from_encoding: 原始编码  :param to_encoding: 目标编码  """  try:  #判断文件内容的编码类型,如果与to_encoding相同则不转换det_encoding, confidence=detect_file_encoding(file_path) if(det_encoding == to_encoding):print(f"{file_path} is already in {to_encoding} encoding")return# 读取文件内容  with open(file_path, 'r', encoding=from_encoding) as file:  content = file.read()  # 写入文件内容到新文件(先写入临时文件,然后替换原文件)  temp_file_path = file_path + '.tmp'  with open(temp_file_path, 'w', encoding=to_encoding, errors='ignore') as file:  file.write(content)  # 替换原文件  os.remove(file_path)  os.rename(temp_file_path, file_path)  print(f"Converted {file_path} from {from_encoding} to {to_encoding}")  except Exception as e:  print(f"Failed to convert {file_path}: {e}")  if __name__ == "__main__":  file_or_folder_to_convert = 'G:/demo/src/gb3l/'  # 修改为你的文件夹路径或文件路径  from_encoding='utf-8'to_encoding  ='gb2312'file_extensions=['.h','.c'] # 修改为你需要转换的文件类型#判断是文件还是文件夹if os.path.isfile(file_or_folder_to_convert): #转换单个文件convert_encoding(file_or_folder_to_convert)  else:#转换文件夹下所有文件for root, dirs, files in os.walk(file_or_folder_to_convert):  for file in files:  #取文件扩展名file_extension = os.path.splitext(file)[1]if (file_extension in file_extensions):  file_path = os.path.join(root, file)   convert_encoding(file_path)

使用的时候只需要修改 代码中的这几个参数即可.

    file_or_folder_to_convert = 'G:/demo/src/gb3l/'  # 修改为你的文件夹路径  from_encoding='utf-8'to_encoding  ='gb2312'file_extensions=['.h','.c'] # 修改为你需要转换的文件类型

使用前需要安装python 3.8以上.
然后使用下面的命令安装chardet 库

	$> pip install chardet 

使用方法, 如下

	$> python convert.py

参数路径什么的, 直接在代码中改.这么简单的代码,是个程序员就会改. 主打一个简单易用.

vscode中指定某种类型的文件打开时的编码格式

按住ctrl+, 在弹出的设置中, 点击右上角的 这个打开json设置图标.
在这里插入图片描述
我的配置如下, .c和.h, 还有.v文件都改成了gb2312编码.

{"git.openRepositoryInParentFolders": "never","Codegeex.Privacy": true,"EIDE.ARM.INI.Path": "d:\\Keil_v5\\UV4\\UV4.exe","terminal.integrated.scrollback": 3000,"workbench.editorAssociations": {"*.c": "default"},"Codegeex.Comment.LanguagePreference": "中文","files.associations": {"*.v": "verilog","*.c": "c","*.h": "c"},"[c]": { "files.encoding": "gb2312" //设置c文件编码},"[verilog]": { "files.encoding": "gb2312" //设置verilog文件编码}
}

这篇关于批量文件编码转换用python实现的utf8转gb2312,vscode设置特殊文件的默认打开编码的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1144884

相关文章

Qt实现对Word网页的读取功能

《Qt实现对Word网页的读取功能》文章介绍了几种在Qt中实现Word文档(.docx/.doc)读写功能的方法,包括基于QAxObject的COM接口调用、DOCX模板替换及跨平台解决方案,重点讨论... 目录1. 核心实现方式2. 基于QAxObject的COM接口调用(Windows专用)2.1 环境

MySQL查看表的历史SQL的几种实现方法

《MySQL查看表的历史SQL的几种实现方法》:本文主要介绍多种查看MySQL表历史SQL的方法,包括通用查询日志、慢查询日志、performance_schema、binlog、第三方工具等,并... 目录mysql 查看某张表的历史SQL1.查看MySQL通用查询日志(需提前开启)2.查看慢查询日志3.

Java实现字符串大小写转换的常用方法

《Java实现字符串大小写转换的常用方法》在Java中,字符串大小写转换是文本处理的核心操作之一,Java提供了多种灵活的方式来实现大小写转换,适用于不同场景和需求,本文将全面解析大小写转换的各种方法... 目录前言核心转换方法1.String类的基础方法2. 考虑区域设置的转换3. 字符级别的转换高级转换

使用Python将PDF表格自动提取并写入Word文档表格

《使用Python将PDF表格自动提取并写入Word文档表格》在实际办公与数据处理场景中,PDF文件里的表格往往无法直接复制到Word中,本文将介绍如何使用Python从PDF文件中提取表格数据,并将... 目录引言1. 加载 PDF 文件并准备 Word 文档2. 提取 PDF 表格并创建 Word 表格

使用Python实现局域网远程监控电脑屏幕的方法

《使用Python实现局域网远程监控电脑屏幕的方法》文章介绍了两种使用Python在局域网内实现远程监控电脑屏幕的方法,方法一使用mss和socket,方法二使用PyAutoGUI和Flask,每种方... 目录方法一:使用mss和socket实现屏幕共享服务端(被监控端)客户端(监控端)方法二:使用PyA

Python列表的创建与删除的操作指南

《Python列表的创建与删除的操作指南》列表(list)是Python中最常用、最灵活的内置数据结构之一,它支持动态扩容、混合类型、嵌套结构,几乎无处不在,但你真的会创建和删除列表吗,本文给大家介绍... 目录一、前言二、列表的创建方式1. 字面量语法(最常用)2. 使用list()构造器3. 列表推导式

Python使用Matplotlib和Seaborn绘制常用图表的技巧

《Python使用Matplotlib和Seaborn绘制常用图表的技巧》Python作为数据科学领域的明星语言,拥有强大且丰富的可视化库,其中最著名的莫过于Matplotlib和Seaborn,本篇... 目录1. 引言:数据可视化的力量2. 前置知识与环境准备2.1. 必备知识2.2. 安装所需库2.3

MyBatis-Plus逻辑删除实现过程

《MyBatis-Plus逻辑删除实现过程》本文介绍了MyBatis-Plus如何实现逻辑删除功能,包括自动填充字段、配置与实现步骤、常见应用场景,并展示了如何使用remove方法进行逻辑删除,逻辑删... 目录1. 逻辑删除的必要性编程1.1 逻辑删除的定义1.2 逻辑删php除的优点1.3 适用场景2.

Python数据验证神器Pydantic库的使用和实践中的避坑指南

《Python数据验证神器Pydantic库的使用和实践中的避坑指南》Pydantic是一个用于数据验证和设置的库,可以显著简化API接口开发,文章通过一个实际案例,展示了Pydantic如何在生产环... 目录1️⃣ 崩溃时刻:当你的API接口又双叒崩了!2️⃣ 神兵天降:3行代码解决验证难题3️⃣ 深度

C#借助Spire.XLS for .NET实现在Excel中添加文档属性

《C#借助Spire.XLSfor.NET实现在Excel中添加文档属性》在日常的数据处理和项目管理中,Excel文档扮演着举足轻重的角色,本文将深入探讨如何在C#中借助强大的第三方库Spire.... 目录为什么需要程序化添加Excel文档属性使用Spire.XLS for .NET库实现文档属性管理Sp