dongpixi2648 2015-10-27 02:04
浏览 72
已采纳

使用utf-8 unicode导出php中的excel文件

I want to export mysql with Php (CodeIgniter) in excel format, but I have problem with UFT-8 characters. it shows the UTF-8 characters ugly.

It is my code

class Excel extends CI_controller{

function index(){

    $this->load->model('user_model');
    $data = $this->user_model->profile_detail_excel();  

      function cleanData(&$str)
      {
        $str = preg_replace("/\t/", "\\t", $str);
        $str = preg_replace("/?
/", "\
", $str);
        if(strstr($str, '"')) $str = '"' . str_replace('"', '""', $str) . '"';
        $str = chr(255).chr(254).mb_convert_encoding( $str, 'UTF-16LE', 'UTF-8');           
        }

      // filename for download
      $filename = "website_data_" . date('Ymd') . ".xls";

    header("Content-Disposition: attachment; filename=\"$filename\"");
    header("Content-Type: application/vnd.ms-excel;  charset=UTF-16LE");


      $flag = false;
      foreach($data as $row) {
        if(!$flag) {
          // display field/column names as first row
          echo implode("\t", array_keys($row)) . "
";
          $flag = true;
        }
        array_walk($row, 'cleanData');
        echo implode("\t", array_values($row)) . "
";
      }
      exit;


}

I appreciate any help

展开全部

  • 写回答

2条回答 默认 最新

  • douluokuang7184 2015-11-07 01:16
    关注

    I use PHPExcel plugin for codeigniter. it works perfect for utf-8

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)
编辑
预览

报告相同问题?

手机看
程序员都在用的中文IT技术交流社区

程序员都在用的中文IT技术交流社区

专业的中文 IT 技术社区,与千万技术人共成长

专业的中文 IT 技术社区,与千万技术人共成长

关注【CSDN】视频号,行业资讯、技术分享精彩不断,直播好礼送不停!

关注【CSDN】视频号,行业资讯、技术分享精彩不断,直播好礼送不停!

客服 返回
顶部