Blame view

vendor/hranicka/csv/src/Reader.php 2.46 KB
fcd9278e   Mihail   parser csv v1
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
  <?php
  
  namespace Hranicka\Csv;
  
  class Reader implements \IteratorAggregate
  {
  
  	/** @var string */
  	private $filePath;
  
  	/** @var bool */
  	private $hasHeaderRow;
  
  	/** @var string */
  	private $delimiter;
  
  	/** @var string */
  	private $enclosure;
  
  	/** @var string */
  	private $escape;
  
  	/** @var resource */
  	private $handler;
  
  	/**
  	 * @param string $filePath CSV file path
  	 * @param bool $hasHeaderRow Is the first row header?
  	 */
  	public function __construct($filePath, $hasHeaderRow = TRUE)
  	{
  		$this->filePath = $filePath;
  		$this->hasHeaderRow = $hasHeaderRow;
  
  		$this->setup();
  	}
  
  	/**
  	 * @param string $delimiter
  	 * @param string $enclosure
  	 * @param string $escape
  	 * @return $this
  	 */
  	public function setup($delimiter = ',', $enclosure = '"', $escape = '\\')
  	{
  		$this->delimiter = $delimiter;
  		$this->enclosure = $enclosure;
  		$this->escape = $escape;
  
  		return $this;
  	}
  
  	public function getIterator()
  	{
  		return new \ArrayIterator($this->read());
  	}
  
  	/**
  	 * @return array
  	 * @throws InvalidFileException
  	 * @deprecated Use ::read instead.
  	 */
  	public function parseAll()
  	{
  		return $this->read();
  	}
  
  	/**
  	 * @return array
  	 * @throws InvalidFileException
  	 */
  	public function read()
  	{
  		$return = [];
  
  		$this->openHandler();
  
  		$line = 0;
  		$keys = NULL;
  
  		while (($row = $this->readRow()) !== FALSE) {
  			$line++;
  
  			if ($this->hasHeaderRow) {
  				if ($keys === NULL) {
  					$keys = array_values($row);
  				} else {
  
  					if (count($keys) !== count($row)) {
2772f19c   Mihail   parser csv v2
90
91
92
93
94
95
96
97
  //                        $rowArr = [$keys, $row];
  //                        echo "<pre>";
  //                        var_dump($rowArr);
  //                        var_dump($return);
  //                        echo "</pre>";
  //                        die;
  //						throw new InvalidFileException("Invalid columns detected on line #$line .");
                          return $return;
fcd9278e   Mihail   parser csv v1
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
  					}
  
  					$return[] = array_combine($keys, $row);
  				}
  			} else {
  				$return[] = $row;
  			}
  		}
  
  		$this->closeHandler();
  
  		return $return;
  	}
  
  	private function openHandler()
  	{
  		$this->handler = fopen($this->filePath, 'r');
  		if ($this->handler === FALSE) {
  			throw new InvalidFileException('Cannot open the file.');
  		}
  	}
  
  	private function closeHandler()
  	{
  		fclose($this->handler);
  		$this->handler = NULL;
  	}
  
  	/**
  	 * @return array|false
  	 */
  	private function readRow()
  	{
  		return fgetcsv($this->handler, NULL, $this->delimiter, $this->enclosure, $this->escape);
  	}
  
  }
  
  class InvalidFileException extends \Exception
  {
  
  }