>백엔드 개발 >PHP 튜토리얼 >Thinkphp5.0을 가져오고 내보내는 방법

Thinkphp5.0을 가져오고 내보내는 방법

小云云
小云云원래의
2017-11-28 09:05:352371검색

ThinkPHP는 무료 오픈 소스이며 빠르고 간단한 객체 지향 경량 PHP 개발 프레임워크입니다. Apache2 오픈 소스 계약에 따라 출시되었으며 엔터프라이즈 수준 애플리케이션 개발과 민첩한 웹 애플리케이션 개발을 단순화하기 위해 탄생했습니다. 이 기사에서는 주로 Thinkphp5.0을 가져오고 내보내는 방법을 공유합니다.

먼저 공식 웹사이트 http://phpexcel.codeplex.com/로 이동하여 최신 PHPExcel을 다운로드하세요

Thinkphp 확장 클래스는 일반적으로 확장 아래에 배치됩니다

컨트롤러 호출을 용이하게 하기 위해 가져오기 및 내보내기를 위한 공개 메소드 작성

엑셀 파일 가져오기

/**
 * 导入excel文件
 * @param  string $file excel文件路径
 * @return array        excel文件内容数组
 */
function import_excel($file){
    // 判断文件是什么格式
    $type = pathinfo($file);
    $type = strtolower($type["extension"]);
    $type=$type==='csv' ? $type : 'Excel5';
    ini_set('max_execution_time', '0');
    Loader::import('PHPExcel.PHPExcel');
 
    // 判断使用哪种格式
    $objReader = PHPExcel_IOFactory::createReader($type);
    $objPHPExcel = $objReader->load($file);
    $sheet = $objPHPExcel->getSheet(0);
    // 取得总行数
    $highestRow = $sheet->getHighestRow();
    // 取得总列数
    $highestColumn = $sheet->getHighestColumn();
 
    //循环读取excel文件,读取一条,插入一条
    $data=array();
    //从第一行开始读取数据
    for($j=1;$j<=$highestRow;$j++){
        //从A列读取数据
        for($k=&#39;A&#39;;$k<=$highestColumn;$k++){
            // 读取单元格
            $data[$j][]=$objPHPExcel->getActiveSheet()->getCell("$k$j")->getValue();
        }
    }
    return $data;
}


배열을 xls 형식의 엑셀 파일로 변환

/**
 * 数组转xls格式的excel文件
 * @param  array  $data      需要生成excel文件的数组
 * @param  string $filename  生成的excel文件名
 *      示例数据:
        $data = array(
            array(NULL, 2010, 2011, 2012),
            array(&#39;Q1&#39;,   12,   15,   21),
            array(&#39;Q2&#39;,   56,   73,   86),
            array(&#39;Q3&#39;,   52,   61,   69),
            array(&#39;Q4&#39;,   30,   32,    0),
           );
 */
function create_xls($data,$filename=&#39;simple.xls&#39;){
    ini_set(&#39;max_execution_time&#39;, &#39;0&#39;);
    Loader::import(&#39;PHPExcel.PHPExcel&#39;);
    $filename=str_replace(&#39;.xls&#39;, &#39;&#39;, $filename).&#39;.xls&#39;;
    $phpexcel = new PHPExcel();
    $phpexcel->getProperties()
        ->setCreator("Maarten Balliauw")
        ->setLastModifiedBy("Maarten Balliauw")
        ->setTitle("Office 2007 XLSX Test Document")
        ->setSubject("Office 2007 XLSX Test Document")
        ->setDescription("Test document for Office 2007 XLSX, generated using PHP classes.")
        ->setKeywords("office 2007 openxml php")
        ->setCategory("Test result file");
    $phpexcel->getActiveSheet()->fromArray($data);
    $phpexcel->getActiveSheet()->setTitle(&#39;Sheet1&#39;);
    $phpexcel->setActiveSheetIndex(0);
    header(&#39;Content-Type: application/vnd.ms-excel&#39;);
    header("Content-Disposition: attachment;filename=$filename");
    header(&#39;Cache-Control: max-age=0&#39;);
    header(&#39;Cache-Control: max-age=1&#39;);
    header (&#39;Expires: Mon, 26 Jul 1997 05:00:00 GMT&#39;); // Date in the past
    header (&#39;Last-Modified: &#39;.gmdate(&#39;D, d M Y H:i:s&#39;).&#39; GMT&#39;); // always modified
    header (&#39;Cache-Control: cache, must-revalidate&#39;); // HTTP/1.1
    header (&#39;Pragma: public&#39;); // HTTP/1.0
    $objwriter = PHPExcel_IOFactory::createWriter($phpexcel, &#39;Excel5&#39;);
    $objwriter->save(&#39;php://output&#39;);
    exit;
}
数据转csv格式的excle
/**
 * 数据转csv格式的excle
 * @param  array $data      需要转的数组
 * @param  string $header   要生成的excel表头
 * @param  string $filename 生成的excel文件名
 *      示例数组:
        $data = array(
            &#39;1,2,3,4,5&#39;,
            &#39;6,7,8,9,0&#39;,
            &#39;1,3,5,6,7&#39;
            );
        $header=&#39;用户名,密码,头像,性别,手机号&#39;;
 */
function create_csv($data,$header=null,$filename=&#39;simple.csv&#39;){
    // 如果手动设置表头;则放在第一行
    if (!is_null($header)) {
        array_unshift($data, $header);
    }
    // 防止没有添加文件后缀
    $filename=str_replace(&#39;.csv&#39;, &#39;&#39;, $filename).&#39;.csv&#39;;
    ob_clean();
    Header( "Content-type:  application/octet-stream ");
    Header( "Accept-Ranges:  bytes ");
    Header( "Content-Disposition:  attachment;  filename=".$filename);
    foreach( $data as $k => $v){
        // 如果是二维数组;转成一维
        if (is_array($v)) {
            $v=implode(&#39;,&#39;, $v);
        }
        // 替换掉换行
        $v=preg_replace(&#39;/\s*/&#39;, &#39;&#39;, $v);
        // 解决导出的数字会显示成科学计数法的问题
        $v=str_replace(&#39;,&#39;, "\t,", $v);
        // 转成gbk以兼容office乱码的问题
        echo iconv(&#39;UTF-8&#39;,&#39;GBK&#39;,$v)."\t\r\n";
    }
}

사용 예:

가져오기 원칙:

가져올 파일을 먼저 Thinkphp 방식으로 서버에 업로드한 후, 업로드된 경로에 따라 공개 가져오기를 호출합니다. 메소드는 가져올 엑셀의 파일 경로를 다음과 같이 전달합니다

public function importUser(){
        $data=import_excel(&#39;./a.xls&#39;);
        print_r($data);
        exit;
    }

위 내용은 Thinkphp5.0 가져오기 및 내보내기에 대한 자세한 설명입니다. 도움이 되었으면 좋겠습니다. 모든 사람.

관련 권장 사항:

thinkphp5에서 데이터베이스에 콘텐츠를 추가하는 방법

Mysql을 데이터베이스로 가져오는 방법

ThinkPHP는 PHPExcel을 사용하여 Excel 데이터 가져오기 및 내보내기 전체 예제를 구현합니다

위 내용은 Thinkphp5.0을 가져오고 내보내는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.