| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406 | 
							- <?php
 
- if (!defined('PHPEXCEL_ROOT')) {
 
-     
 
-     define('PHPEXCEL_ROOT', dirname(__FILE__) . '/../../');
 
-     require(PHPEXCEL_ROOT . 'PHPExcel/Autoloader.php');
 
- }
 
- class PHPExcel_Reader_CSV extends PHPExcel_Reader_Abstract implements PHPExcel_Reader_IReader
 
- {
 
-     
 
-     private $inputEncoding = 'UTF-8';
 
-     
 
-     private $delimiter = ',';
 
-     
 
-     private $enclosure = '"';
 
-     
 
-     private $sheetIndex = 0;
 
-     
 
-     private $contiguous = false;
 
-     
 
-     private $contiguousRow = -1;
 
-     
 
-     public function __construct()
 
-     {
 
-         $this->readFilter = new PHPExcel_Reader_DefaultReadFilter();
 
-     }
 
-     
 
-     protected function isValidFormat()
 
-     {
 
-         return true;
 
-     }
 
-     
 
-     public function setInputEncoding($pValue = 'UTF-8')
 
-     {
 
-         $this->inputEncoding = $pValue;
 
-         return $this;
 
-     }
 
-     
 
-     public function getInputEncoding()
 
-     {
 
-         return $this->inputEncoding;
 
-     }
 
-     
 
-     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;
 
-         }
 
-     }
 
-     
 
-     protected function checkSeparator()
 
-     {
 
-         $line = fgets($this->fileHandle);
 
-         if ($line === false) {
 
-             return;
 
-         }
 
-         if ((strlen(trim($line, "\r\n")) == 5) && (stripos($line, 'sep=') === 0)) {
 
-             $this->delimiter = substr($line, 4, 1);
 
-             return;
 
-         }
 
-         return $this->skipBOM();
 
-     }
 
-     
 
-     public function listWorksheetInfo($pFilename)
 
-     {
 
-         
 
-         $this->openFile($pFilename);
 
-         if (!$this->isValidFormat()) {
 
-             fclose($this->fileHandle);
 
-             throw new PHPExcel_Reader_Exception($pFilename . " is an Invalid Spreadsheet file.");
 
-         }
 
-         $fileHandle = $this->fileHandle;
 
-         
 
-         $this->skipBOM();
 
-         $this->checkSeparator();
 
-         $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;
 
-         
 
-         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;
 
-         
 
-         fclose($fileHandle);
 
-         return $worksheetInfo;
 
-     }
 
-     
 
-     public function load($pFilename)
 
-     {
 
-         
 
-         $objPHPExcel = new PHPExcel();
 
-         
 
-         return $this->loadIntoExisting($pFilename, $objPHPExcel);
 
-     }
 
-     
 
-     public function loadIntoExisting($pFilename, PHPExcel $objPHPExcel)
 
-     {
 
-         $lineEnding = ini_get('auto_detect_line_endings');
 
-         ini_set('auto_detect_line_endings', true);
 
-         
 
-         $this->openFile($pFilename);
 
-         if (!$this->isValidFormat()) {
 
-             fclose($this->fileHandle);
 
-             throw new PHPExcel_Reader_Exception($pFilename . " is an Invalid Spreadsheet file.");
 
-         }
 
-         $fileHandle = $this->fileHandle;
 
-         
 
-         $this->skipBOM();
 
-         $this->checkSeparator();
 
-         
 
-         while ($objPHPExcel->getSheetCount() <= $this->sheetIndex) {
 
-             $objPHPExcel->createSheet();
 
-         }
 
-         $sheet = $objPHPExcel->setActiveSheetIndex($this->sheetIndex);
 
-         $escapeEnclosures = array( "\\" . $this->enclosure,
 
-                                    $this->enclosure . $this->enclosure
 
-                                  );
 
-         
 
-         $currentRow = 1;
 
-         if ($this->contiguous) {
 
-             $currentRow = ($this->contiguousRow == -1) ? $sheet->getHighestRow(): $this->contiguousRow;
 
-         }
 
-         
 
-         while (($rowData = fgetcsv($fileHandle, 0, $this->delimiter, $this->enclosure)) !== false) {
 
-             $columnLetter = 'A';
 
-             foreach ($rowData as $rowDatum) {
 
-                 if ($rowDatum != '' && $this->readFilter->readCell($columnLetter, $currentRow)) {
 
-                     
 
-                     $rowDatum = str_replace($escapeEnclosures, $this->enclosure, $rowDatum);
 
-                     
 
-                     if ($this->inputEncoding !== 'UTF-8') {
 
-                         $rowDatum = PHPExcel_Shared_String::ConvertEncoding($rowDatum, 'UTF-8', $this->inputEncoding);
 
-                     }
 
-                     
 
-                     $sheet->getCell($columnLetter . $currentRow)->setValue($rowDatum);
 
-                 }
 
-                 ++$columnLetter;
 
-             }
 
-             ++$currentRow;
 
-         }
 
-         
 
-         fclose($fileHandle);
 
-         if ($this->contiguous) {
 
-             $this->contiguousRow = $currentRow;
 
-         }
 
-         ini_set('auto_detect_line_endings', $lineEnding);
 
-         
 
-         return $objPHPExcel;
 
-     }
 
-     
 
-     public function getDelimiter()
 
-     {
 
-         return $this->delimiter;
 
-     }
 
-     
 
-     public function setDelimiter($pValue = ',')
 
-     {
 
-         $this->delimiter = $pValue;
 
-         return $this;
 
-     }
 
-     
 
-     public function getEnclosure()
 
-     {
 
-         return $this->enclosure;
 
-     }
 
-     
 
-     public function setEnclosure($pValue = '"')
 
-     {
 
-         if ($pValue == '') {
 
-             $pValue = '"';
 
-         }
 
-         $this->enclosure = $pValue;
 
-         return $this;
 
-     }
 
-     
 
-     public function getSheetIndex()
 
-     {
 
-         return $this->sheetIndex;
 
-     }
 
-     
 
-     public function setSheetIndex($pValue = 0)
 
-     {
 
-         $this->sheetIndex = $pValue;
 
-         return $this;
 
-     }
 
-     
 
-     public function setContiguous($contiguous = false)
 
-     {
 
-         $this->contiguous = (bool) $contiguous;
 
-         if (!$contiguous) {
 
-             $this->contiguousRow = -1;
 
-         }
 
-         return $this;
 
-     }
 
-     
 
-     public function getContiguous()
 
-     {
 
-         return $this->contiguous;
 
-     }
 
- }
 
 
  |