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
|
<?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
*/
|
9ef73019
Mihail
parser
|
44
|
public function setup($delimiter = ';', $enclosure = '"', $escape = '\\')
|
fcd9278e
Mihail
parser csv v1
|
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
|
{
$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
|
// $rowArr = [$keys, $row];
// echo "<pre>";
// var_dump($rowArr);
// var_dump($return);
// echo "</pre>";
// die;
|
9ef73019
Mihail
parser
|
96
97
|
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
{
}
|