>  기사  >  백엔드 개발  >  phpExcel을 사용하여 Excel 데이터 가져오기 및 내보내기

phpExcel을 사용하여 Excel 데이터 가져오기 및 내보내기

不言
不言원래의
2018-05-08 14:38:431059검색

이 글은 주로 phpExcel을 사용하여 Excel 데이터를 가져오고 내보내는 방법을 소개합니다. 이제 이를 공유합니다. 도움이 필요한 친구들이 참고할 수 있습니다.

이 루틴은 의 개발 프레임워크에 사용됩니다. Thinkphp.같은 방법을 다른 프레임워크에서 사용한다면 많은 분들이 엑셀 가져오기, 내보내기를 제대로 구현하지 못할 수도 있는데, 문제는 기본적으로 phpExcel의 핵심 클래스 참조 경로에 문제가 있는 것입니다. Lu Jin이 올바르게 참조되었는지 확인해야 합니다. Test

많은 기사에서 phpExcel을 사용하여 Excel 데이터를 가져오고 내보내는 것을 언급합니다. 대부분의 기사가 유사하거나 재인쇄되며 몇 가지 문제가 있을 수 있습니다. phpExcel의 사용 루틴을 연구하면서 바로 요점을 살펴보겠습니다.

우선 이 루틴을 Thinkphp의 개발 프레임워크에서 사용한다는 점을 말씀드리자면, 다른 프레임워크에서도 같은 방식으로 사용한다면 많은 분들이 엑셀 가져오기, 내보내기를 제대로 구현하지 못할 수도 있습니다. 문제는 기본적으로 phpExcel입니다. 핵심 클래스 참조 경로가 잘못되었습니다. 문제가 있으면 Lu Jin이 올바르게 참조되는지 테스트해야 합니다.

(1) Excel 가져오기

먼저 전면 HTML 페이지에 파일을 업로드합니다. 예:

코드 복사 코드는 다음과 같습니다.

<form method="post" action="php文件" enctype="multipart/form-data">
         <h3>导入Excel表:</h3><input  type="file" name="file_stu" />
           <input type="submit"  value="导入" />
</form>

두 번째, 파일을 업로드합니다. 해당 PHP 파일 처리

코드 복사 코드는 다음과 같습니다.

 if (! empty ( $_FILES [&#39;file_stu&#39;] [&#39;name&#39;] ))
 {
    $tmp_file = $_FILES [&#39;file_stu&#39;] [&#39;tmp_name&#39;];
    $file_types = explode ( ".", $_FILES [&#39;file_stu&#39;] [&#39;name&#39;] );
    $file_type = $file_types [count ( $file_types ) - 1];
     /*判别是不是.xls文件,判别是不是excel文件*/
     if (strtolower ( $file_type ) != "xls")              
    {
          $this->error ( &#39;不是Excel文件,重新上传&#39; );
     }
    /*设置上传路径*/
     $savePath = SITE_PATH . &#39;/public/upfile/Excel/&#39;;
    /*以时间来命名上传的文件*/
     $str = date ( &#39;Ymdhis&#39; ); 
     $file_name = $str . "." . $file_type;
     /*是否上传成功*/
     if (! copy ( $tmp_file, $savePath . $file_name )) 
      {
          $this->error ( &#39;上传失败&#39; );
      }
    /*
       *对上传的Excel数据进行处理生成编程数据,这个函数会在下面第三步的ExcelToArray类中
      注意:这里调用执行了第三步类里面的read函数,把Excel转化为数组并返回给$res,再进行数据库写入
    */
  $res = Service ( &#39;ExcelToArray&#39; )->read ( $savePath . $file_name );
   /*
        重要代码 解决Thinkphp M、D方法不能调用的问题  
        如果在thinkphp中遇到M 、D方法失效时就加入下面一句代码
    */
   //spl_autoload_register ( array (&#39;Think&#39;, &#39;autoload&#39; ) );
   /*对生成的数组进行数据库的写入*/
   foreach ( $res as $k => $v ) 
   {
       if ($k != 0) 
      {
           $data [&#39;uid&#39;] = $v [0];
           $data [&#39;password&#39;] = sha1 ( &#39;111111&#39; );
           $data [&#39;email&#39;] = $v [1];
           $data [&#39;uname&#39;] = $v [3];
          $data [&#39;institute&#39;] = $v [4];
         $result = M ( &#39;user&#39; )->add ( $data );
         if (! $result) 
         {
              $this->error ( &#39;导入数据库失败&#39; );
          }
      }
   }
}

세 번째: ExcelToArrary 클래스, phpExcel을 참조하고 엑셀 데이터를 처리하는 데 사용됩니다

코드 복사코드는 다음과 같습니다.

class ExcelToArrary extends Service{
 public function __construct() {
     /*导入phpExcel核心类    注意 :你的路径跟我不一样就不能直接复制*/
     include_once(&#39;./Excel/PHPExcel.php&#39;);
 }
/**
* 读取excel $filename 路径文件名 $encode 返回数据的编码 默认为utf8
*以下基本都不要修改
*/
public function read($filename,$encode=&#39;utf-8&#39;){
          $objReader = PHPExcel_IOFactory::createReader(&#39;Excel5&#39;);
          $objReader->setReadDataOnly(true);
          $objPHPExcel = $objReader->load($filename);
          $objWorksheet = $objPHPExcel->getActiveSheet();
    $highestRow = $objWorksheet->getHighestRow(); 
    $highestColumn = $objWorksheet->getHighestColumn(); 
      $highestColumnIndex = PHPExcel_Cell::columnIndexFromString($highestColumn); 
      $excelData = array(); 
    for ($row = 1; $row <= $highestRow; $row++) { 
        for ($col = 0; $col < $highestColumnIndex; $col++) { 
                 $excelData[$row][] =(string)$objWorksheet->getCellByColumnAndRow($col, $row)->getValue();
           } 
         } 
        return $excelData;
    }    
 }

넷째, 위 내용은 모두 Import된 Content이며, 마지막에 phpExcel 패키지가 첨부되어 있습니다.

(2) Excel 내보내기(가져오기보다 훨씬 간단함)

먼저 데이터베이스에서 Excel을 생성하기 위한 데이터를 찾습니다. data


코드 복사

코드는 다음과 같습니다

$data= M(&#39;User&#39;)->findAll();   //查出数据
$name=&#39;Excelfile&#39;;    //生成的Excel文件文件名
$res=service(&#39;ExcelToArrary&#39;)->push($data,$name);
셋째, 위는 내보내기 전체 내용이며, 마지막에 phpExcel 패키지가 첨부되어 있습니다.

관련 권장 사항:

thinkPHP+phpexcel은 Excel 보고서 출력 기능 예제를 구현합니다

Thinkphp5+PHPExcel은 일괄 업로드 테이블 데이터 기능을 구현합니다


위 내용은 phpExcel을 사용하여 Excel 데이터 가져오기 및 내보내기의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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