当前位置: 首页 > news >正文

linux下查看文件编码及修改编码

查看文件编码
在Linux中查看文件编码可以通过以下几种方式:
1.在Vim中可以直接查看文件编码
:set fileencoding
即可显示文件编码格式。
如果你只是想查看其它编码格式的文件或者想解决用Vim查看文件乱码的问题,那么你可以在
~/.vimrc 文件中添加以下内容:

set encoding=utf-8 fileencodings=ucs-bom,utf-8,cp936

这样,就可以让vim自动识别文件编码(可以自动识别UTF-8或者GBK编码的文件),其实就是依照 fileencodings提供的编码列表尝试,如果没有找到合适的编码,就用latin-1(ASCII)编码打开。
2. enca (如果你的系统中没有安装这个命令,可以用sudo yum install -y enca 安装 )查看文件编码
$ enca filename
filename: Universal transformation format 8 bits; UTF-8
CRLF line terminators
需要说明一点的是,enca对某些GBK编码的文件识别的不是很好,识别时会出现:
Unrecognized encoding

文件编码转换
1.在Vim中直接进行转换文件编码,比如将一个文件转换成utf-8格式
:set fileencoding=utf-8

2. enconv 转换文件编码,比如要将一个GBK编码的文件转换成UTF-8编码,操作如下
enconv -L zh_CN -x UTF-8 filename

3. iconv 转换,iconv的命令格式如下:
iconv -f encoding -t encoding inputfile
比如将一个UTF-8 编码的文件转换成GBK编码
iconv -f UTF-8 -t GBK file1 -o file2

查看文件编码file命令
file ip.txt  ip.txt: UTF-8 Unicode text, with escape sequences
一、利用iconv命令进行编码转换文件内容编码转换  iconv命令用于转换指定文件的编码,默认输出到标准输出设备,亦可指定输出文件。  用法: iconv [选项...] [文件...]  有如下选项可用:  输入/输出格式规范:  -f, --from-code=名称 原始文本编码  -t, --to-code=名称 输出编码  信息:  -l, --list 列举所有已知的字符集    输出控制:  -c 从输出中忽略无效的字符  -o, --output=FILE 输出文件  -s, --silent 关闭警告  --verbose 打印进度信息  -?, --help 给出该系统求助列表  --usage 给出简要的用法信息  -V, --version 打印程序版本号    例子:  iconv -f utf-8 -t gb2312 aaa.txt >bbb.txt  这个命令读取aaa.txt文件,从utf-8编码转换为gb2312编码,其输出定向到bbb.txt文件。
二、文件名编码转换
因为现在用linux,原来在windows里的文件都是用GBK编码的。所以copy到linux下是乱码,文件内容可以用iconv来转换可是好多中文的文件名还是乱码,找到个可以转换文件名编码的命令,就是convmv。
convmv命令详细参数  例如
convmv -f GBK -t UTF-8 *.mp3
不过这个命令不会直正的转换,你可以看到转换前后的对比。如果要直正的转换要加上参数 --notest
convmv -f GBK -t UTF-8 --notest *.mp3
-f 参数是指出转换前的编码,-t 是转换后的编码。这个千万不要弄错了。不然可能还是乱码哦。还有一个参数很有用。就是 -r 这个表示递归转换当前目录下的所有子目录。
* 需要安装 convmv-1.10-1.el5.noarch.rpm  
三、  更好的傻瓜型命令行工具enca,它不但能智能的识别文件的编码,而且还支持成批转换。    1.安装    
$sudo apt-get install enca    
2.查看当前文件编码    
enca -L zh_CN ip.txt     Simplified Chinese National Standard; GB2312     Surrounded by/intermixed with non-text data    
3.转换    命令格式如下    
$enca -L 当前语言 -x 目标编码 文件名    
例如要把当前目录下的所有文件都转成utf-8    
enca -L zh_CN -x utf-8 *     
检查文件的编码 enca -L zh_CN file     
 将文件编码转换为"UTF-8"编码  enca -L zh_CN -x UTF-8 file
如果不想覆盖原文件可以这样         enca -L zh_CN -x UTF-8 < file1 > file2 

相关文章:

  • nginx https配置
  • 挨踢部落故事汇(7): 结缘51CTO志在高远
  • canvas做的桌面
  • 多个极路由配置桥接模式共同ssid上网
  • jmeter接口系列:时间戳、加密
  • Python练习3
  • Silverlight 解谜游戏 之二 创建题板
  • Linux下Elasticsearch-5.1.2简单集群搭建
  • 文件系统fdisk、gdisk、parted
  • JDK源码分析-Integer
  • 全栈必备 Java 基础
  • 深度学习:Gibbs 采样
  • Linux基础管理——sed(文本处理三剑客)
  • pyqt4_应用例子(计算器,对话框,进度条,日历等等)
  • MySql(零):Linux(CentOS7)下安装和配置MySQL5.7.20(安装包安装)
  • 【许晓笛】 EOS 智能合约案例解析(3)
  • 【跃迁之路】【585天】程序员高效学习方法论探索系列(实验阶段342-2018.09.13)...
  • FineReport中如何实现自动滚屏效果
  • Java IO学习笔记一
  • Making An Indicator With Pure CSS
  • NLPIR语义挖掘平台推动行业大数据应用服务
  • Spring声明式事务管理之一:五大属性分析
  • vue-cli3搭建项目
  • 安卓应用性能调试和优化经验分享
  • 从伪并行的 Python 多线程说起
  • 搞机器学习要哪些技能
  • 构建二叉树进行数值数组的去重及优化
  • 关于 Cirru Editor 存储格式
  • 关于springcloud Gateway中的限流
  • 区块链将重新定义世界
  • 我们雇佣了一只大猴子...
  • ​马来语翻译中文去哪比较好?
  • # 安徽锐锋科技IDMS系统简介
  • #Linux杂记--将Python3的源码编译为.so文件方法与Linux环境下的交叉编译方法
  • (3)llvm ir转换过程
  • (70min)字节暑假实习二面(已挂)
  • (C++)八皇后问题
  • (C语言)字符分类函数
  • (深度全面解析)ChatGPT的重大更新给创业者带来了哪些红利机会
  • (已解决)vue+element-ui实现个人中心,仿照原神
  • .bat文件调用java类的main方法
  • .NET Core跨平台微服务学习资源
  • .NET/C# 反射的的性能数据,以及高性能开发建议(反射获取 Attribute 和反射调用方法)
  • .NET/C# 将一个命令行参数字符串转换为命令行参数数组 args
  • .NET开发不可不知、不可不用的辅助类(一)
  • .NET企业级应用架构设计系列之开场白
  • .NET学习教程二——.net基础定义+VS常用设置
  • /proc/vmstat 详解
  • @property @synthesize @dynamic 及相关属性作用探究
  • [2016.7.Test1] T1 三进制异或
  • [2024] 十大免费电脑数据恢复软件——轻松恢复电脑上已删除文件
  • [BZOJ2208][Jsoi2010]连通数
  • [C++]18:set和map的使用
  • [CF]Codeforces Round #551 (Div. 2)
  • [CLickhouse] 学习小计