linux字符编码转换的函数
函数1:iconv_t iconv_open(const char *tocode, const char *fromcode);
描述:初始化创建一个字符编码转换描述符。
返回值:成功则创建,失败返回-1,并这支errno.
函数
头文件:#include 函数1:iconv_t iconv_open(const char *tocode, const char *fromcode); 描述:初始化创建一个字符编码转换描述符。 返回值:成功则创建,失败返回-1,并这支errno. 函数2:size_t iconv (iconv_t cd, const char* * inbuf, size_t * inbytesleft, char* * outbuf, size_t * outbytesleft); 描述:参数cd必须是由iconv_open函数创建的转换描述符。大部分情形是inbuf 不为NULL,*inbuf也不为NULL。这种情况下,iconv函数将以*inbuf起始的多字节序列转换到以*outbuf起始的多字节序列。从*inbuf开始读取,最多*inbytesleft字节,转换后,从*outbuf开始写入,最多*outbytesleft字节。iconv函数一次转换一个多字节字符,每次字符转换,*inbuf增加已转换的字节数,*inbytesleft相应地减少已转换的字节数;对应地,*outbuf和*outbytesleft作相应的修改,同时修改cd的转换状态。 以下四种情况不能完成转换: 1.输入中含无效的多字节序列。此时,它将errno设置为EILSEQ并返回(size_t)(-1)。*inbuf指向无效序列的最左端。 2.输入的字节序列已经全部被转换过linux编码,也就是*inbytesleft减少至0。此时,iconv返回本次调用中完成转换的数目(可逆的转换不计入)。 3.输入中以不完整多字节序列作结尾。此时,它将errno设置为EINVAL并返回(size_t)(-1)。*inbuf指向不完整多字节序列的最左端。 函数3:int iconv_close(iconv_t cd); 描述:释放掉开始由iconv_open()创建的描述符。 返回值:成功返回0,失败返回-1,并设置errno。 注释:在转换过程中,要注意字符编码的问题,如果已经为utf-8在继续操作会有多字节转换的报错问题出现。 可以通过把结果导入文件,在浏览器下打开文件,如果可以正常显示就是相应字符编码。 (编辑:老爷爷站长网) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |