當前位置: 首頁>>代碼示例>>PHP>>正文


PHP SplFileObject::getCsvControl方法代碼示例

本文整理匯總了PHP中SplFileObject::getCsvControl方法的典型用法代碼示例。如果您正苦於以下問題:PHP SplFileObject::getCsvControl方法的具體用法?PHP SplFileObject::getCsvControl怎麽用?PHP SplFileObject::getCsvControl使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在SplFileObject的用法示例。


在下文中一共展示了SplFileObject::getCsvControl方法的4個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的PHP代碼示例。

示例1: getEnclosure

 /**
  * @return string
  */
 public function getEnclosure()
 {
     if ($this->enclosure === null) {
         list($delimiter, $this->enclosure) = $this->csvFile->getCsvControl();
     }
     return $this->enclosure;
 }
開發者ID:spryker,項目名稱:Library,代碼行數:10,代碼來源:CsvMeta.php

示例2: SplFileObject

<?php

$file = new SplFileObject(__DIR__ . '/csv.csv');
$file->setFlags(SplFileObject::READ_CSV);
$file->setCsvControl(';');
var_dump($file->getCsvControl());
foreach ($file as $line) {
    var_dump($line);
    exit;
}
開發者ID:ezoic,項目名稱:hhvm,代碼行數:10,代碼來源:csv.php

示例3: SplFileObject

<?php

$obj = new SplFileObject(dirname(__FILE__) . '/SplFileObject_testinput.csv');
var_dump($obj->getCsvControl());
開發者ID:badlamer,項目名稱:hhvm,代碼行數:4,代碼來源:SplFileObject_getCsvControl_basic_001.php

示例4: readFile

 /**
  * read file using phpexcel library
  *
  * @param string $source
  * @return array
  */
 private function readFile($source, $limit = null)
 {
     //load the phpexcel IOFactory class
     include $this->_docRoot . '/vendor/phpoffice/phpexcel/Classes/PHPExcel/IOFactory.php';
     //prepare the reader,
     try {
         $type = PHPExcel_IOFactory::identify($source);
         if (stripos($type, 'excel') === false && stripos($type, 'csv') === false) {
             $error = ['error' => 'This is not a spreadsheet file.'];
             return $error;
         }
         $reader = PHPExcel_IOFactory::createReader($type);
         //if type is csv (.csv or .txt), find the delimeter
         if ($type == 'CSV') {
             $csvChecker = new SplFileObject($source);
             $csvProperty = $csvChecker->getCsvControl();
             $delimiter = $csvProperty[0];
             $reader->setDelimiter($delimiter);
         }
         $object = $reader->load($source);
     } catch (Exception $e) {
         $error = ['error' => 'I cannot read the file.'];
         return $error;
     }
     //extract the data from the first sheet of the file
     try {
         $sheet = $object->getSheet(0);
         $rows = $sheet->getHighestRow();
         $columns = $sheet->getHighestColumn();
     } catch (Exception $e) {
         $error = ['error' => 'I cannot process the first sheet.'];
         return $error;
     }
     //there should be at least 1 row of data
     if ($rows < 1) {
         $error = ['error' => 'There is not enough data to read.'];
         return $error;
     }
     //read just first 10 rows if it is not for full processing
     $last = $rows;
     $max = !$limit || $rows < $limit + 1 ? $rows : $limit;
     //read the data, metadata into keys and data into data
     $data = [];
     try {
         for ($row = 1; $row <= $max; $row++) {
             $data[] = $sheet->rangeToArray('A' . $row . ':' . $columns . $row, NULL, TRUE, FALSE);
         }
         //add last row if not full processing
         if ($limit && $rows > 10) {
             $data[] = $sheet->rangeToArray('A' . $last . ':' . $columns . $last, NULL, TRUE, FALSE);
         }
     } catch (Exception $e) {
         $error = ['error' => 'I cannot read the data.'];
         return $error;
     }
     if (!is_numeric($columns)) {
         $range = range('A', 'Z');
         $columns = array_search($columns, $range) + 1;
     }
     return ['data' => $data, 'columns' => $columns];
 }
開發者ID:axelcho,項目名稱:zend_test,代碼行數:67,代碼來源:ApiController.php


注:本文中的SplFileObject::getCsvControl方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。