dongwo2772 2012-05-30 10:46
浏览 54
已采纳

PHP utf-8由char读取文件

I have some serious problem dealing with files in php with utf-8 encoding. I need to read a file char by char or possibly line by line, with fixed small chunks. I tried to use fgetc and fgets but characters encoded in utf8 are split in a few "chars" instead of only one. I'm trying to find a solution, it could be even a small "string" containing only the character in Unicode but it must be read from file properly.

Pseudo code I would like to use:

while ( ($c == read_utf8_char($file)) != false ) {
    if ($c == 'ó') do_something();
}

I would appreciate your help.

  • 写回答

1条回答 默认 最新

  • dongqin1819 2012-05-30 10:51
    关注
    function mb_str_split($string) { 
        return preg_split('/(?<!^)(?!$)/u', $string ); 
    } 
    
    $chars = mb_str_split($file);
    
    foreach ($chars as $c) {
        if ($c == 'ó') do_something();
    }
    

    ~ Source: http://www.php.net/manual/en/function.mb-split.php#99851

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥15 组策略中的计算机配置策略无法下发
  • ¥15 机器学习简单问题解决
  • ¥15 如何绘制动力学系统的相图
  • ¥15 对接wps接口实现获取元数据
  • ¥20 给自己本科IT专业毕业的妹m找个实习工作
  • ¥15 用友U8:向一个无法连接的网络尝试了一个套接字操作,如何解决?
  • ¥30 我的代码按理说完成了模型的搭建、训练、验证测试等工作(标签-网络|关键词-变化检测)
  • ¥50 mac mini外接显示器 画质字体模糊
  • ¥15 TLS1.2协议通信解密
  • ¥40 图书信息管理系统程序编写