linux下如何转换文本的字符编码

linux下如何转换文本的字符编码

linux提供了将文本从一个字符集编码转换成另一种字符集编码的相关命令和函数。

查看系统的编码方式与修改

  1. locale命令可以查看系统当前的编码方式。如LANG=en_US.UTF-8.代表语言是en_US(美式英语),编码是UTF-8。
  2. 可以通过修改/etc/sysconfig/i18n文件中的具体段修改编码方式。

字符编码转换命令

  1. iconv
    1. 描述:将文本从一个字符集编码转换成另一种字符集编码。(如将utf-8格式的文本转换成gb2312格式)。
    2. 语法:iconv [options] [-f from-encoding] [-t to-encoding] [inputfile]...
    3. 选项:
      1. -f:输入文本的编码格式。如GB2312.
      2. -t:输出文本的编码格式。如utf-8.如果后缀//IGNORE(如utf-8//IGNORE),遇到识别不了的字符则停止转换并退出。如果后缀//TRANSLIT,遇到识别不了的字符,使用相近的代替或者?代替.
      3. -l:打印所有可传化的字符集。
      4. -o:设置输出文件的名称。
      5. -c:当遇到无法转换的字符时,应该默默地丢弃它们,而不是终止它们.
    4. eg:iconv -f "utf-8" -t "GB2312" xxx.txt -o xxxGB2312.txt

用户空间字符编码转换相关函数

  1. 包含头文件:#include <iconv.h>

  2. iconv_t iconv_open(const char *tocode, const char *fromcode)

    1. 描述:为字符集编码转换分配一个描述符。
    2. tocode:转换后文本的编码格式.具体格式可用iconv --list命令查看。如果后缀//IGNORE(如utf-8//IGNORE),遇到识别不了的字符则直接丢弃。如果后缀//TRANSLIT,遇到识别不了的字符,使用相近的代替或者?代替.
    3. fromcode:当前文本的编码格式.
    4. return:出错:-1.正确:返回描述符。
  3. int iconv_close(iconv_t cd)

    1. 描述:销毁为字符集编码转换分配的描述符。
    2. cd:要销毁的描述符.
  4. size_t iconv(iconv_t cd,char **inbuf, size_t *inbytesleft,char **outbuf, size_t *outbytesleft)

    1. 描述:将文本从一个字符集编码转换成另一种字符集编码。(如将utf-8格式的文本转换成gb2312格式)。
    2. cd: 由iconv_open()函数返回的转化描述符。
    3. inbuf:指向需要转换的字符串首地址的指针变量地址。
    4. inbytesleft:字符串中未转换的字节数的变量地址。iconv()在转换过程中会修改此变量的内容值。当转换完成时,此变量的值变为0.
    5. outbuf:指向输出缓冲区首地址的指针变量地址。
    6. outbytesleft: 指向outbuf剩余空间大小的变量地址。
    7. return:
      1. 失败:-1。使用errno查看具体错误值。
      2. 成功,返回调用期间执行的不可逆转换的数量。可逆转换不计算在内。

使用例程如下:

#include<stdio.h>
#include <iconv.h>
#include <stdlib.h>
#include <string.h>
#include <stdint.h>

void main(void)
{

    char inBuff[] = "2020武汉加油";
    size_t inBuffLen = strlen(inBuff);
    //由于iconv()会改变传入参数的值,所以创建临时变量fromLen、*pIn存放。
    size_t fromLen = inBuffLen;
    char *pIn = inBuff;

    //存放转化结果
    const size_t outBuffLen = 32;
    char outBuff[outBuffLen];
    //由于iconv()会改变传入参数的值,所以创建临时变量fromLen、*pIn存放。
    size_t toLen = outBuffLen;
    char *pOut = outBuff;

    printf("fromLen:%lu  toLen:%lu\n",fromLen,toLen);

    printf("utf-8编码: ");
    for(int i = 0; i < inBuffLen; i++){
        printf("%02X ",(uint8_t)inBuff[i]);
    }

    iconv_t icd = iconv_open("GB2312","UTF-8");
    if ((iconv_t)-1 == icd){
        printf("open error");
        return;
    }

    size_t tempLen = iconv(icd,&pIn,&fromLen,&pOut,&toLen);

    if (tempLen == -1){
        printf("iconv error");
        return;
    }

    printf("\ngb2312编码:");

    //这个长度是转换结果的长度
    size_t temp2len = outBuffLen - toLen;
    for(int i = 0; i < temp2len; i++){
        printf("%02X ",(uint8_t)outBuff[i]);
    }
    printf("\n");

    iconv_close(icd);
}

关于技术交流

此处后的文字已经和题目内容无关,可以不看。
qq群:825695030
微信公众号:嵌入式的日常
如果上面的文章对你有用,欢迎打赏、点赞、评论。二维码

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

theboynoName

感谢鼓励

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值