PHP使用PHPExcel刪除Excel儲存格指定列的方法_php技巧

來源:互聯網
上載者:User

本文執行個體講述了PHP使用PHPExcel刪除Excel儲存格指定列的方法。分享給大家供大家參考,具體如下:

需求是這樣的:

有一個系統僅公司內部和外部經銷商使用,在一個匯出功能中公司內部員工跟外部經銷商匯出的列是不一樣的(某些資料是不能提供給經銷商的)
因為匯出的資料都是一樣的(某些列外資料外部沒有)因此並沒有單獨處理,而是統一產生然後根據不同的賬戶再刪除沒有許可權的列

/*** @Author:   HTL* @Description: 移出單元列* @objPHPExcel: phpexecel object* @remove_columns:要移出的列*/function _remove_column($objPHPExcel,$remove_columns){    if(!$objPHPExcel      || !is_object ($objPHPExcel)      || !$remove_columns      || !is_array($remove_columns)      || count($remove_columns)<=0) return ;    //儲存格模板值,用於匹配要刪除的列(在excel模板第一列)    $cell_val = '';    //儲存格總列數    $highestColumm = $objPHPExcel->getActiveSheet()->getHighestColumn();    for ($column = 'A'; $column <= $highestColumm;) {      //列數是以A列開始      $cell_val = $objPHPExcel->getActiveSheet()->getCell($column."1");      $cell_val = preg_replace("/[\s{}]/i","", $cell_val);      //移出沒有許可權匯出的列      //移出後column不能加1,因為當前列已經移出加1後會導致刪除錯誤的列      //此問題浪費了幾十分鐘      if(strlen($cell_val)>0 && in_array($cell_val,$remove_columns))      {        $objPHPExcel->getActiveSheet()->removeColumn( $column);      }      else      {        $column++;      }    }}//example//匯入PHPExcel類vendor("PHPExcel.PHPExcel");$filepath = './data/upload/temp.xlsx';$objReader = \PHPExcel_IOFactory::createReader('Excel2007');$objPHPExcel = $objReader->load($filepath);$this->_remove_column($objPHPExcel,array("age","address"));

運行效果如下圖所示:

更多關於PHP相關內容感興趣的讀者可查看本站專題:《php操作office文檔技巧總結(包括word,excel,access,ppt)》、《PHP數組(Array)操作技巧大全》、《php排序演算法總結》、《PHP常用遍曆演算法與技巧總結》、《PHP資料結構與演算法教程》、《php程式設計演算法總結》、《PHP數學運算技巧總結》、《phpRegex用法總結》、《PHP運算與運算子用法總結》、《php字串(string)用法總結》及《php常見資料庫操作技巧匯總》

希望本文所述對大家PHP程式設計有所協助。

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.