416 lines
		
	
	
		
			9.2 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			416 lines
		
	
	
		
			9.2 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
| <?php
 | |
| /**
 | |
|  * PHPExcel
 | |
|  *
 | |
|  * Copyright (c) 2006 - 2014 PHPExcel
 | |
|  *
 | |
|  * This library is free software; you can redistribute it and/or
 | |
|  * modify it under the terms of the GNU Lesser General Public
 | |
|  * License as published by the Free Software Foundation; either
 | |
|  * version 2.1 of the License, or (at your option) any later version.
 | |
|  *
 | |
|  * This library is distributed in the hope that it will be useful,
 | |
|  * but WITHOUT ANY WARRANTY; without even the implied warranty of
 | |
|  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
 | |
|  * Lesser General Public License for more details.
 | |
|  *
 | |
|  * You should have received a copy of the GNU Lesser General Public
 | |
|  * License along with this library; if not, write to the Free Software
 | |
|  * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301  USA
 | |
|  *
 | |
|  * @category   PHPExcel
 | |
|  * @package    PHPExcel_Reader
 | |
|  * @copyright  Copyright (c) 2006 - 2014 PHPExcel (http://www.codeplex.com/PHPExcel)
 | |
|  * @license    http://www.gnu.org/licenses/old-licenses/lgpl-2.1.txt	LGPL
 | |
|  * @version    ##VERSION##, ##DATE##
 | |
|  */
 | |
| 
 | |
| 
 | |
| /** PHPExcel root directory */
 | |
| if (!defined('PHPEXCEL_ROOT')) {
 | |
| 	/**
 | |
| 	 * @ignore
 | |
| 	 */
 | |
| 	define('PHPEXCEL_ROOT', dirname(__FILE__) . '/../../');
 | |
| 	require(PHPEXCEL_ROOT . 'PHPExcel/Autoloader.php');
 | |
| }
 | |
| 
 | |
| /**
 | |
|  * PHPExcel_Reader_CSV
 | |
|  *
 | |
|  * @category   PHPExcel
 | |
|  * @package    PHPExcel_Reader
 | |
|  * @copyright  Copyright (c) 2006 - 2014 PHPExcel (http://www.codeplex.com/PHPExcel)
 | |
|  */
 | |
| class PHPExcel_Reader_CSV extends PHPExcel_Reader_Abstract implements PHPExcel_Reader_IReader
 | |
| {
 | |
| 	/**
 | |
| 	 * Input encoding
 | |
| 	 *
 | |
| 	 * @access	private
 | |
| 	 * @var	string
 | |
| 	 */
 | |
| 	private $_inputEncoding	= 'UTF-8';
 | |
| 
 | |
| 	/**
 | |
| 	 * Delimiter
 | |
| 	 *
 | |
| 	 * @access	private
 | |
| 	 * @var string
 | |
| 	 */
 | |
| 	private $_delimiter		= ',';
 | |
| 
 | |
| 	/**
 | |
| 	 * Enclosure
 | |
| 	 *
 | |
| 	 * @access	private
 | |
| 	 * @var	string
 | |
| 	 */
 | |
| 	private $_enclosure		= '"';
 | |
| 
 | |
| 	/**
 | |
| 	 * Line ending
 | |
| 	 *
 | |
| 	 * @access	private
 | |
| 	 * @var	string
 | |
| 	 */
 | |
| 	private $_lineEnding	= PHP_EOL;
 | |
| 
 | |
| 	/**
 | |
| 	 * Sheet index to read
 | |
| 	 *
 | |
| 	 * @access	private
 | |
| 	 * @var	int
 | |
| 	 */
 | |
| 	private $_sheetIndex	= 0;
 | |
| 
 | |
| 	/**
 | |
| 	 * Load rows contiguously
 | |
| 	 *
 | |
| 	 * @access	private
 | |
| 	 * @var	int
 | |
| 	 */
 | |
| 	private $_contiguous	= false;
 | |
| 
 | |
| 	/**
 | |
| 	 * Row counter for loading rows contiguously
 | |
| 	 *
 | |
| 	 * @var	int
 | |
| 	 */
 | |
| 	private $_contiguousRow	= -1;
 | |
| 
 | |
| 
 | |
| 	/**
 | |
| 	 * Create a new PHPExcel_Reader_CSV
 | |
| 	 */
 | |
| 	public function __construct() {
 | |
| 		$this->_readFilter		= new PHPExcel_Reader_DefaultReadFilter();
 | |
| 	}
 | |
| 
 | |
| 	/**
 | |
| 	 * Validate that the current file is a CSV file
 | |
| 	 *
 | |
| 	 * @return boolean
 | |
| 	 */
 | |
| 	protected function _isValidFormat()
 | |
| 	{
 | |
| 		return TRUE;
 | |
| 	}
 | |
| 
 | |
| 	/**
 | |
| 	 * Set input encoding
 | |
| 	 *
 | |
| 	 * @param string $pValue Input encoding
 | |
| 	 */
 | |
| 	public function setInputEncoding($pValue = 'UTF-8')
 | |
| 	{
 | |
| 		$this->_inputEncoding = $pValue;
 | |
| 		return $this;
 | |
| 	}
 | |
| 
 | |
| 	/**
 | |
| 	 * Get input encoding
 | |
| 	 *
 | |
| 	 * @return string
 | |
| 	 */
 | |
| 	public function getInputEncoding()
 | |
| 	{
 | |
| 		return $this->_inputEncoding;
 | |
| 	}
 | |
| 
 | |
| 	/**
 | |
| 	 * Move filepointer past any BOM marker
 | |
| 	 *
 | |
| 	 */
 | |
| 	protected function _skipBOM()
 | |
| 	{
 | |
| 		rewind($this->_fileHandle);
 | |
| 
 | |
| 		switch ($this->_inputEncoding) {
 | |
| 			case 'UTF-8':
 | |
| 				fgets($this->_fileHandle, 4) == "\xEF\xBB\xBF" ?
 | |
| 					fseek($this->_fileHandle, 3) : fseek($this->_fileHandle, 0);
 | |
| 				break;
 | |
| 			case 'UTF-16LE':
 | |
| 				fgets($this->_fileHandle, 3) == "\xFF\xFE" ?
 | |
| 					fseek($this->_fileHandle, 2) : fseek($this->_fileHandle, 0);
 | |
| 				break;
 | |
| 			case 'UTF-16BE':
 | |
| 				fgets($this->_fileHandle, 3) == "\xFE\xFF" ?
 | |
| 					fseek($this->_fileHandle, 2) : fseek($this->_fileHandle, 0);
 | |
| 				break;
 | |
| 			case 'UTF-32LE':
 | |
| 				fgets($this->_fileHandle, 5) == "\xFF\xFE\x00\x00" ?
 | |
| 					fseek($this->_fileHandle, 4) : fseek($this->_fileHandle, 0);
 | |
| 				break;
 | |
| 			case 'UTF-32BE':
 | |
| 				fgets($this->_fileHandle, 5) == "\x00\x00\xFE\xFF" ?
 | |
| 					fseek($this->_fileHandle, 4) : fseek($this->_fileHandle, 0);
 | |
| 				break;
 | |
| 			default:
 | |
| 				break;
 | |
| 		}
 | |
| 	}
 | |
| 
 | |
| 	/**
 | |
| 	 * Return worksheet info (Name, Last Column Letter, Last Column Index, Total Rows, Total Columns)
 | |
| 	 *
 | |
| 	 * @param 	string 		$pFilename
 | |
| 	 * @throws	PHPExcel_Reader_Exception
 | |
| 	 */
 | |
| 	public function listWorksheetInfo($pFilename)
 | |
| 	{
 | |
| 		// Open file
 | |
| 		$this->_openFile($pFilename);
 | |
| 		if (!$this->_isValidFormat()) {
 | |
| 			fclose ($this->_fileHandle);
 | |
| 			throw new PHPExcel_Reader_Exception($pFilename . " is an Invalid Spreadsheet file.");
 | |
| 		}
 | |
| 		$fileHandle = $this->_fileHandle;
 | |
| 
 | |
| 		// Skip BOM, if any
 | |
| 		$this->_skipBOM();
 | |
| 
 | |
| 		$escapeEnclosures = array( "\\" . $this->_enclosure, $this->_enclosure . $this->_enclosure );
 | |
| 
 | |
| 		$worksheetInfo = array();
 | |
| 		$worksheetInfo[0]['worksheetName'] = 'Worksheet';
 | |
| 		$worksheetInfo[0]['lastColumnLetter'] = 'A';
 | |
| 		$worksheetInfo[0]['lastColumnIndex'] = 0;
 | |
| 		$worksheetInfo[0]['totalRows'] = 0;
 | |
| 		$worksheetInfo[0]['totalColumns'] = 0;
 | |
| 
 | |
| 		// Loop through each line of the file in turn
 | |
| 		while (($rowData = fgetcsv($fileHandle, 0, $this->_delimiter, $this->_enclosure)) !== FALSE) {
 | |
| 			$worksheetInfo[0]['totalRows']++;
 | |
| 			$worksheetInfo[0]['lastColumnIndex'] = max($worksheetInfo[0]['lastColumnIndex'], count($rowData) - 1);
 | |
| 		}
 | |
| 
 | |
| 		$worksheetInfo[0]['lastColumnLetter'] = PHPExcel_Cell::stringFromColumnIndex($worksheetInfo[0]['lastColumnIndex']);
 | |
| 		$worksheetInfo[0]['totalColumns'] = $worksheetInfo[0]['lastColumnIndex'] + 1;
 | |
| 
 | |
| 		// Close file
 | |
| 		fclose($fileHandle);
 | |
| 
 | |
| 		return $worksheetInfo;
 | |
| 	}
 | |
| 
 | |
| 	/**
 | |
| 	 * Loads PHPExcel from file
 | |
| 	 *
 | |
| 	 * @param 	string 		$pFilename
 | |
| 	 * @return PHPExcel
 | |
| 	 * @throws PHPExcel_Reader_Exception
 | |
| 	 */
 | |
| 	public function load($pFilename)
 | |
| 	{
 | |
| 		// Create new PHPExcel
 | |
| 		$objPHPExcel = new PHPExcel();
 | |
| 
 | |
| 		// Load into this instance
 | |
| 		return $this->loadIntoExisting($pFilename, $objPHPExcel);
 | |
| 	}
 | |
| 
 | |
| 	/**
 | |
| 	 * Loads PHPExcel from file into PHPExcel instance
 | |
| 	 *
 | |
| 	 * @param 	string 		$pFilename
 | |
| 	 * @param	PHPExcel	$objPHPExcel
 | |
| 	 * @return 	PHPExcel
 | |
| 	 * @throws 	PHPExcel_Reader_Exception
 | |
| 	 */
 | |
| 	public function loadIntoExisting($pFilename, PHPExcel $objPHPExcel)
 | |
| 	{
 | |
| 		$lineEnding = ini_get('auto_detect_line_endings');
 | |
| 		ini_set('auto_detect_line_endings', true);
 | |
| 
 | |
| 		// Open file
 | |
| 		$this->_openFile($pFilename);
 | |
| 		if (!$this->_isValidFormat()) {
 | |
| 			fclose ($this->_fileHandle);
 | |
| 			throw new PHPExcel_Reader_Exception($pFilename . " is an Invalid Spreadsheet file.");
 | |
| 		}
 | |
| 		$fileHandle = $this->_fileHandle;
 | |
| 
 | |
| 		// Skip BOM, if any
 | |
| 		$this->_skipBOM();
 | |
| 
 | |
| 		// Create new PHPExcel object
 | |
| 		while ($objPHPExcel->getSheetCount() <= $this->_sheetIndex) {
 | |
| 			$objPHPExcel->createSheet();
 | |
| 		}
 | |
| 		$sheet = $objPHPExcel->setActiveSheetIndex($this->_sheetIndex);
 | |
| 
 | |
| 		$escapeEnclosures = array( "\\" . $this->_enclosure,
 | |
| 								   $this->_enclosure . $this->_enclosure
 | |
| 								 );
 | |
| 
 | |
| 		// Set our starting row based on whether we're in contiguous mode or not
 | |
| 		$currentRow = 1;
 | |
| 		if ($this->_contiguous) {
 | |
| 			$currentRow = ($this->_contiguousRow == -1) ? $sheet->getHighestRow(): $this->_contiguousRow;
 | |
| 		}
 | |
| 
 | |
| 		// Loop through each line of the file in turn
 | |
| 		while (($rowData = fgetcsv($fileHandle, 0, $this->_delimiter, $this->_enclosure)) !== FALSE) {
 | |
| 			$columnLetter = 'A';
 | |
| 			foreach($rowData as $rowDatum) {
 | |
| 				if ($rowDatum != '' && $this->_readFilter->readCell($columnLetter, $currentRow)) {
 | |
| 					// Unescape enclosures
 | |
| 					$rowDatum = str_replace($escapeEnclosures, $this->_enclosure, $rowDatum);
 | |
| 
 | |
| 					// Convert encoding if necessary
 | |
| 					if ($this->_inputEncoding !== 'UTF-8') {
 | |
| 						$rowDatum = PHPExcel_Shared_String::ConvertEncoding($rowDatum, 'UTF-8', $this->_inputEncoding);
 | |
| 					}
 | |
| 
 | |
| 					// Set cell value
 | |
| 					$sheet->getCell($columnLetter . $currentRow)->setValue($rowDatum);
 | |
| 				}
 | |
| 				++$columnLetter;
 | |
| 			}
 | |
| 			++$currentRow;
 | |
| 		}
 | |
| 
 | |
| 		// Close file
 | |
| 		fclose($fileHandle);
 | |
| 
 | |
| 		if ($this->_contiguous) {
 | |
| 			$this->_contiguousRow = $currentRow;
 | |
| 		}
 | |
| 
 | |
| 		ini_set('auto_detect_line_endings', $lineEnding);
 | |
| 
 | |
| 		// Return
 | |
| 		return $objPHPExcel;
 | |
| 	}
 | |
| 
 | |
| 	/**
 | |
| 	 * Get delimiter
 | |
| 	 *
 | |
| 	 * @return string
 | |
| 	 */
 | |
| 	public function getDelimiter() {
 | |
| 		return $this->_delimiter;
 | |
| 	}
 | |
| 
 | |
| 	/**
 | |
| 	 * Set delimiter
 | |
| 	 *
 | |
| 	 * @param	string	$pValue		Delimiter, defaults to ,
 | |
| 	 * @return	PHPExcel_Reader_CSV
 | |
| 	 */
 | |
| 	public function setDelimiter($pValue = ',') {
 | |
| 		$this->_delimiter = $pValue;
 | |
| 		return $this;
 | |
| 	}
 | |
| 
 | |
| 	/**
 | |
| 	 * Get enclosure
 | |
| 	 *
 | |
| 	 * @return string
 | |
| 	 */
 | |
| 	public function getEnclosure() {
 | |
| 		return $this->_enclosure;
 | |
| 	}
 | |
| 
 | |
| 	/**
 | |
| 	 * Set enclosure
 | |
| 	 *
 | |
| 	 * @param	string	$pValue		Enclosure, defaults to "
 | |
| 	 * @return PHPExcel_Reader_CSV
 | |
| 	 */
 | |
| 	public function setEnclosure($pValue = '"') {
 | |
| 		if ($pValue == '') {
 | |
| 			$pValue = '"';
 | |
| 		}
 | |
| 		$this->_enclosure = $pValue;
 | |
| 		return $this;
 | |
| 	}
 | |
| 
 | |
| 	/**
 | |
| 	 * Get line ending
 | |
| 	 *
 | |
| 	 * @return string
 | |
| 	 */
 | |
| 	public function getLineEnding() {
 | |
| 		return $this->_lineEnding;
 | |
| 	}
 | |
| 
 | |
| 	/**
 | |
| 	 * Set line ending
 | |
| 	 *
 | |
| 	 * @param	string	$pValue		Line ending, defaults to OS line ending (PHP_EOL)
 | |
| 	 * @return PHPExcel_Reader_CSV
 | |
| 	 */
 | |
| 	public function setLineEnding($pValue = PHP_EOL) {
 | |
| 		$this->_lineEnding = $pValue;
 | |
| 		return $this;
 | |
| 	}
 | |
| 
 | |
| 	/**
 | |
| 	 * Get sheet index
 | |
| 	 *
 | |
| 	 * @return integer
 | |
| 	 */
 | |
| 	public function getSheetIndex() {
 | |
| 		return $this->_sheetIndex;
 | |
| 	}
 | |
| 
 | |
| 	/**
 | |
| 	 * Set sheet index
 | |
| 	 *
 | |
| 	 * @param	integer		$pValue		Sheet index
 | |
| 	 * @return PHPExcel_Reader_CSV
 | |
| 	 */
 | |
| 	public function setSheetIndex($pValue = 0) {
 | |
| 		$this->_sheetIndex = $pValue;
 | |
| 		return $this;
 | |
| 	}
 | |
| 
 | |
| 	/**
 | |
| 	 * Set Contiguous
 | |
| 	 *
 | |
| 	 * @param boolean $contiguous
 | |
| 	 */
 | |
| 	public function setContiguous($contiguous = FALSE)
 | |
| 	{
 | |
| 		$this->_contiguous = (bool) $contiguous;
 | |
| 		if (!$contiguous) {
 | |
| 			$this->_contiguousRow = -1;
 | |
| 		}
 | |
| 
 | |
| 		return $this;
 | |
| 	}
 | |
| 
 | |
| 	/**
 | |
| 	 * Get Contiguous
 | |
| 	 *
 | |
| 	 * @return boolean
 | |
| 	 */
 | |
| 	public function getContiguous() {
 | |
| 		return $this->_contiguous;
 | |
| 	}
 | |
| 
 | |
| }
 | 
