Linux 文件编码问题及iconv命令
iconv命令是运行于linux/unix平台的文件编码装换工具。当我们在linux/unix系统shell查看文本文件时,常常会发现文件的中文是乱码的,这是由于文本文件的编码与当前操作系统设置的编码不同而引起的,这时可以使用iconv进行编码转换,从而解决乱码问题。
解决文本文件乱码问题分3步:1.确定文件编码,2.确定iconv是否支持此编码的转换,3.确定Linux/Unix操作系统编码,4.转换文件编码为与系统编码一致;下面通过对test.txt文件来举例。
1、 使用file命令来确定文件编码:
- $ file -bi gbk.txt | sed -e 's/.*[ ]charset=//' |tr '[a-z]' '[A-Z'
- ISO-8859-1
可见test.txt文件编码为ISO-8859-1编码。
2、 使用iconv -l确定iconv是否支持此种编码的转换:
- $ iconv -l | grep ISO-8859-1
- ISO-8859-1//
- ISO-8859-10//
- ISO-8859-11//
- ISO-8859-13//
- ISO-8859-14//
- ISO-8859-15//
- ISO-8859-16//
3、 确定Linux/Unix操作系统编码:
- $ echo $LANG
- zh_CN.UTF-8
当前操作系统坏境编码为"UTF-8"
4、 转换编码
- $ iconv -f ISO-8859-1 -t UTF-8 test.txt
- 测试
注:由于file命令常常会误判编码,如发现转换出来的编码依然是乱码,可将iconv -f的输入编码换成其他常用编码试试: GBK、BIG5、HZ、GB2312、GB18030、ASCII
iconv命令的详细语法:
iconv [选项..] 文件
选项:
-f 输入编码
-t 输出编码
-l 列出所有已知的编码
-o 输出文件
附录字符编码表:
编码集:
| ISO-8859-2 | ISO 8859-2 standard; ISO Latin 2 |
| ISO-8859-4 | ISO 8859-4 standard; Latin 4 |
| ISO-8859-5 | ISO 8859-5 standard; ISO Cyrillic |
| ISO-8859-13 | ISO 8859-13 standard; ISO Baltic; Latin 7 |
| ISO-8859-16 | ISO 8859-16 standard |
| CP1125 | MS-windows code page 1125 |
| CP1250 | MS-Windows code page 1250 |
| CP1251 | MS-Windows code page 1251 |
| CP1257 | MS-Windows code page 1257; WinBaltRim |
| IBM852 | IBM/MS code page 852; PC (DOS) Latin 2 |
| IBM855 | IBM/MS code page 855 |
| IBM775 | IBM/MS code page 775 |
| IBM866 | IBM/MS code page 866 |
| baltic | ISO-IR-179; Baltic |
| KEYBCS2 | Kamenicky encoding; KEYBCS2 |
| macce | Macintosh Central European |
| maccyr | Macintosh Cyrillic |
| ECMA-113 | Ecma Cyrillic; ECMA-113 |
| KOI-8_CS_2 | KOI8-CS2 code ('T602') |
| KOI8-R | KOI8-R Cyrillic |
| KOI8-U | KOI8-U Cyrillic |
| KOI8-UNI | KOI8-Unified Cyrillic |
| TeX | (La)TeX control sequences |
| UCS-2 | Universal character set 2 bytes; UCS-2; BMP |
| UCS-4 | Universal character set 4 bytes; UCS-4; ISO-10646 |
| UTF-7 | Universal transformation format 7 bits; UTF-7 |
| UTF-8 | Universal transformation format 8 bits; UTF-8 |
| CORK | Cork encoding; T1 |
| GBK | Simplified Chinese National Standard; GB2312 |
| BIG5 | Traditional Chinese Industrial Standard; Big5 |
| HZ | HZ encoded GB2312 |
行结束符:
| /LF | LF line terminators |
| /CRLF | CRLF line terminators |
| N.A. | Mixed line terminators |
| N.A. | Surrounded by/intermixed with non-text data |
| /21 | Byte order reversed in pairs (1,2 -> 2,1) |
| /4321 | Byte order reversed in quadruples (1,2,3,4 -> 4,3,2,1) |
| N.A. | Both little and big endian chunks, concatenated |
| /qp | Quoted-printable encoded |
各国语言编码集:
| Bulgarian | CP1251 ISO-8859-5 IBM855 maccyr ECMA-113 |
| Czech | ISO-8859-2 CP1250 IBM852 KEYBCS2 macce KOI-8_CS_2 CORK |
| Estonian | ISO-8859-4 CP1257 IBM775 ISO-8859-13 macce baltic |
| Croatian | CP1250 ISO-8859-2 IBM852 macce CORK |
| Hungarian | ISO-8859-2 CP1250 IBM852 macce CORK |
| Lithuanian | CP1257 ISO-8859-4 IBM775 ISO-8859-13 macce baltic |
| Latvian | CP1257 ISO-8859-4 IBM775 ISO-8859-13 macce baltic |
| Polish | ISO-8859-2 CP1250 IBM852 macce ISO-8859-13 ISO-8859-16 baltic CORK |
| Russian | KOI8-R CP1251 ISO-8859-5 IBM866 maccyr |
| Slovak | CP1250 ISO-8859-2 IBM852 KEYBCS2 macce KOI-8_CS_2 CORK |
| Slovene | ISO-8859-2 CP1250 IBM852 macce CORK |
| Ukrainian | CP1251 IBM855 ISO-8859-5 CP1125 KOI8-U maccyr |
| Chinese | GBK BIG5 HZ |
Linux 文件编码问题及iconv命令的更多相关文章
- (转)剖析Linux文件编码的查看及修改
Linux文件编码的查看和修改都有不止一种做法,如果你需要在Linux中操作windows下的文件,那么很可能会经常遇到文件编码转换的问题,如何进行这项工作,也应该是经常工作在双系统下的操作者的必须掌 ...
- 在Linux/Unix系统下用iconv命令处理文本文件中文乱码问题
iconv命令是运行于linux/unix平台的文件编码装换工具.当我们在linux/unix系统shell查看文本文件时,常常会发现文件的中文是乱码的,这是由于文本文件的编码与当前操作系统设置的编码 ...
- windows linux 文件编码转换
查看文件编码在Linux中查看文件编码可以通过以下几种方式:1.在Vim中可以直接查看文件编码:set fileencoding即可显示文件编码格式.如果你只是想查看其它编码格式的文件或者想解决用Vi ...
- linux文件编码
linux下新建一个文件,或采用fopen新建,那么文件的编码是什么? 怎么查看文件编码格式: 查看文件编码file命令file ip.txt ip.txt: UTF-8 Unicode text, ...
- linux 文件编码问题
iconv -f UTF- -t gb18030 file_input -o file_output 上述命令不一定有用. 大概了解下文件编码,和vim里面的编码情况. 1 字符编码基础知识 字符编码 ...
- Linux文件权限查看及修改命令chmod
查看权限 Linux文件访问权限分为可读,可写和可执行三种. 可用ls -l命令查看,例: ls -l或者 ll 显示为 -r--r--r--. 1 root root 21 Jan 5 23:02 ...
- Linux文件权限查看及修改命令chmod,chown
查看权限 Linux文件访问权限分为可读,可写和可执行三种. 可用ls -l命令查看,例: ls -l或者 ll 显示为 -r--r--r--. 1 root root 21 Jan 5 23:02 ...
- Linux文件与目录管理常用命令
Linux文件与目录常用命令管理: 文件权限/目录权限: -rwxr-xr-x. root root Mar : zeng.txt r():可读 w():可写 x():可执行 drwxr-xr-x. ...
- Linux文件与目录操作 ls 命令(2)
说文件操作是最频繁地操作也不为过,在Linux中,使用ls命令可以列出当前目录中所有内容,本篇就先说说ls命令.本文所说的文件指文件和目录. ls命令常用选项 -a:显示指定目录下所有子目录与文件,包 ...
随机推荐
- c++ 反射类型
来自: 实现代码=== // // Created by lizhen on 2017/9/29. // #ifndef BOOST_ALL_CALLBACKFUNCTION_H #define BO ...
- Ubuntu 配置 Android 开发 环境
. 果断换Ubuntu了, Ubuntu的截图效果不好, 不能设置阴影 ... 作者 : 万境绝尘 转载请注明出处 : http://blog.csdn.net/shulianghan/article ...
- 什么是POJO模式
1. 什么是POJO POJO的名称有多种,pure old java object .plain ordinary java object 等. 按照Martin Fowler的解释是“Pl ...
- lintcode-148-颜色分类
148-颜色分类 给定一个包含红,白,蓝且长度为 n 的数组,将数组元素进行分类使相同颜色的元素相邻,并按照红.白.蓝的顺序进行排序. 我们可以使用整数 0,1 和 2 分别代表红,白,蓝. 注意事项 ...
- TCP系列17—重传—7、SACK下的重传
我们之前介绍SACK选项的时候说过,SACK可以把接收端系列号空间的洞反映给发送端,因此发送端可以更充分的理解接收端的情况,而进行更好的重传恢复过程.这种过程有时候也叫做advanced loss r ...
- 【log4net】- 非常完善的Log4net详细说明
1.概述 log4net是.Net下一个非常优秀的开源日志记录组件.log4net记录日志的功能非常强大.它可以将日志分不同的等级,以不同的格式,输出到不同的媒介.本文主要是介绍如何在Visual S ...
- MongoDB、ElasticSearch、Redis、HBase这四种热门数据库的优缺点及应用场景
MongoDB MongoDB是当今最火爆的NoSQL数据库.MongoDB最早在09年发布,算得上是早期大数据时代的数据库代表作了.随着MongoDB的火爆,研发MongoDB的团队还专门成立了Mo ...
- Jekyll 使用 Rouge 主题
今日发现我的 Github Pages 中的代码并没有高亮,看了一下代码发现,原来的没有设置 css 样式的原因,我使用的代码高亮器是 rouge highlighter: rouge Rouge 是 ...
- css样式 一定要reset?
有大神讲过了,直接看http://www.zhangxinxu.com/wordpress/?p=758
- BZOJ 1202 狡猾的商人(带权并查集)
给出了l,r,w.我们就得知了s[r]-s[l-1]=w.也就是说,点l-1和点r的距离为w. 于是可以使用带权并查集,定义dis[i]表示点i到根节点的距离.查询和合并的时候维护一下就OK了. 如果 ...