>  기사  >  백엔드 개발  >  PHP는 CSV 파일을 생성

PHP는 CSV 파일을 생성

不言
不言원래의
2018-04-27 15:00:103418검색

이 문서의 내용은 특정 참조 가치가 있습니다. 이제 모든 사람과 공유합니다. 도움이 필요한 친구들이 참조할 수 있습니다.

더 이상 말도 안되는 내용은 다음과 같습니다.

방법 1:

/** * 导出excel(csv) 
* @data 导出数据 
* @headlist 第一行,列名 
* @fileName 输出Excel文件名 
*/
function csv_export($data = array(), $headlist = array(), $fileName)
 {    
 header('Content-Type: application/vnd.ms-excel');    
 header('Content-Disposition: attachment;filename="'.$fileName.'.csv"');    
 header('Cache-Control: max-age=0');    
 //打开PHP文件句柄,php://output 表示直接输出到浏览器    
 $fp = fopen('php://output', 'a');// 打开文件资源,不存在则创建 
    //输出Excel列名信息    
 foreach ($headlist as $key => $value) {        
 //CSV的Excel支持GBK编码,一定要转换,否则乱码        
 $headlist[$key] = iconv('utf-8', 'gbk', $value);    
 }    
 //将数据通过fputcsv写到文件句柄    
 fputcsv($fp, $headlist);    
 //计数器    
 $num = 0;    
 //每隔$limit行,刷新一下输出buffer,不要太大,也不要太小    
 $limit = 100000;    
 //逐行取出数据,不浪费内存    
 $count = count($data);    
 for ($i = 0; $i < $count; $i++) {        
 $num++;        
 //刷新一下输出buffer,防止由于数据过多造成问题       
  if ($limit == $num) {            
  ob_flush();           
   flush();           
    $num = 0;        
    }        
    $row = $data[$i];        
    foreach ($row as $key => $value) {            
    $row[$key] = iconv('utf-8', 'gbk', $value);        
    }        
    fputcsv($fp, $row);    
    }
    }

방법 2:

public function getExportLog(){   
if (! $this->valid_admin ( @$_SERVER ['PHP_AUTH_USER'], @$_SERVER ['PHP_AUTH_PW'] )) {
//$_SERVER ['PHP_AUTH_USER']浏览器接受的用户名输入      
header ( 'WWW-Authenticate: Basic realm=""' );//浏览器弹出输入用户名密码提示框      
header ( 'HTTP/1.0 401 Unauthorized' );      
echo "You need to enter a valid username and  password.";      
exit ();   
}       
$oViewLog = new DbsPatientViewLog();       
$result = $oViewLog->getAllInfo();      
$sname =  time();   
$dataname=date('Ymd');   
$exportdir = public_path()."/exportfile/".$dataname."/";   
if(!is_dir($exportdir)) 
   {      mkdir($exportdir,0777,true);   
   }   //生成csv文件   $elsfile=$exportdir.$sname.'.csv';       
   $fp = fopen($elsfile, 'w');       
   $data="";       
   $title=implode(',', array('医脉通加密ID','医脉通ID','文章ID','参与的活动','访问活动首页的时间','访问记录信息页面的时间','参与活动的方式'));       
   $data=$title;       
   foreach($result as $value)   
       {           
       $line=implode(',', array($value['meduid_old'],                            
       $value['meduid'],                             
       $value['msgid'],                             
       $value['hd_way']==1?'疑似患者转诊':'DES试纸',                             
       $value['view_at'],                             
       $value['view_at_show'],                             
       $value['view_way']==1?'mobile':$value['view_way']==2?'微信浏览器': 'PC',                                  
       )           
       );              
       $data=$data."\r\n".$line;      
        } 
       $data=iconv("UTF-8", "GBK//IGNORE", $data);      fwrite($fp,$data); // 写入数据      
       fclose($fp); //关闭文件句柄   
       $download_dir= "/exportfile/".$dataname.'/'.$sname.'.csv';   
       header("Content-type:text/csv");   
    header("Content-Disposition:attachment;filename=".$sname.'.csv');   
    header('Cache-Control:must-revalidate,post-check=0,pre-check=0');   
    header('Expires:0');   
    header('Pragma:public');   
    echo $data;}

위의 두 가지 방법이지만 실제로는 하나의

프로세스로 간주할 수 있습니다.

1. 지정된 파일을 열려면 fopen() 함수를 사용하세요.

2. 배열인 제목을 처리합니다. 그렇다면 fputcsv()를 사용하여 첫 번째 코드 조각처럼 파일 핸들에 데이터를 직접 쓰거나 두 번째 코드 조각을 사용하여 implode() 함수를 사용하여 분할할 수 있습니다.

3. 데이터를 처리하기 위해 첫 번째 단락은 데이터를 한 줄씩 파일로 변환하여 파일에 기록하는 것입니다. 두 번째 섹션은 implode()를 사용하여 데이터를 분할하고 최종적으로 전체 데이터를 접합하는 것입니다. 참고: fwrite()는 데이터를 쓰고

4 파일 핸들을 닫습니다

요약: csv 파일을 생성하는 과정은 다음과 같습니다. 첫 번째는 과도한 데이터로 인해 발생하는 문제를 방지하기 위해 정기적으로 메모리를 절약하고 출력 버퍼를 새로 고치는 것입니다

관련 권장 사항:

PHP 생성 지정된 숫자 확인 코드 및 제어 가능한 간섭 요소

php는 워드 파일을 생성합니다

PHP는 지정된 숫자 확인 코드 및 제어 가능한 간섭 요소를 생성합니다. 2부





위 내용은 PHP는 CSV 파일을 생성의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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