头文件:#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.输入的字节序列已经全部被转换过,也就是*inbytesleft减少至0。此时,iconv返回本次调用中完成转换的数目(可逆的转换不计入)。
3.输入中以不完整多字节序列作结尾。此时,它将errno设置为EINVAL并返回(size_t)(-1)。*inbuf指向不完整多字节序列的最左端。
函数3:int iconv_close(iconv_t cd);
描述:释放掉开始由iconv_open()创建的描述符。
返回值:成功返回0,失败返回-1,并设置errno。
注释:在转换过程中,要注意字符编码的问题,如果已经为utf-8在继续操作会有多字节转换的报错问题出现。
可以通过把结果导入文件,在浏览器下打开文件,如果可以正常显示就是相应字符编码。
阅读(2172) | 评论(0) | 转发(0) |