Unicode 文件的读写(C)

假设你有一个文档test.txt是UNICODE格式的

从test中读出写到test2中

int main(void)
{
    FILE *file = fopen("test.txt", "rb");
    if (file == NULL)
    {
        fprintf(stderr, "Source file open error./n");
        return -1;
    }

    wchar_t buf[1024];
    fseek(file,2,0);
    FILE *file2 = fopen("test2.txt", "wb");
    fputwc(L'/xFEFF', file2);
    while (!feof(file))
    {
        int len = 0;
        fgetws(buf, 1024, file);
        //wprintf(L"%ls", buf);
        fputws(buf,file2);
    }

    fclose(file);
    fclose(file2);  

    return 0;
}

 

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
C语言文件操作中文显示乱的问题通常是由于编码问题引起的。在C语言中,文件默认以二进制形式进行读写,因此如果直接读写包含中文字符的文件,可能会导致中文显示乱码。为了解决这个问题,可以使用以下方法: 1. 使用文本模式打开文件:在打开文件时,可以使用文本模式打开文件,以便正确处理中文字符。例如,使用`fopen`函数打开文件时,将文件模式设置为`"r"`(读取)或`"w"`(写入)等,并在模式字符串后面添加`"t"`,表示以文本模式打开文件。例如: ```c FILE* file = fopen("filename.txt", "rt"); ``` 2. 设置文件编码:如果文件中的中文字符采用的是特定的编码方式(如UTF-8),则需要在读写文件之前设置正确的编码方式。可以使用`setlocale`函数设置文件编码。例如,使用UTF-8编码的文件可以使用以下代码设置编码: ```c setlocale(LC_ALL, "en_US.UTF-8"); ``` 3. 使用宽字符函数:如果需要读写包含宽字符(如Unicode字符)的文件,可以使用宽字符函数来处理。例如,可以使用`fgetwc`和`fputwc`函数来读写宽字符。示例代码如下: ```c wint_t ch = fgetwc(file); // 读取宽字符 fputwc(ch, file); // 写入宽字符 ``` 需要注意的是,以上方法仅适用于C语言中的文件操作。如果在其他环境中进行文件操作(如Windows API或其他编程语言),可能需要使用相应的方法来处理中文显示乱码的问题。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值