이 문서의 내용은 특정 참조 가치가 있습니다. 이제 모든 사람과 공유합니다. 도움이 필요한 친구들이 참조할 수 있습니다.
더 이상 말도 안되는 내용은 다음과 같습니다.
방법 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는 지정된 숫자 확인 코드 및 제어 가능한 간섭 요소를 생성합니다. 2부
위 내용은 PHP는 CSV 파일을 생성의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!