3v4l.org

run code in 300+ PHP versions simultaneously
<?php $fo = new \SplFileObject('import_mmt_20140701.csv', 'r'); $processedBrands = []; $processedModels = []; $lastBrand = ''; foreach ($fo as $line) { isset($i) ? ++$i : $i = 0; if ($i === 0) continue; if (empty($line)) continue; // Countries (assume country names are already converted to the correct ones): list($countryName, $description, $name) = str_getcsv($line, ';'); $countryName = trim($countryName); $description = trim($description); $name = trim($name); if (!in_array($name, $processedBrands) && !empty($countryName) && !empty($name)) { save_brand([ 'status' => 1, 'country' => $countryName, 'countryId' => item_country($countryName), 'reference' => str_url($name), 'name' => $name, 'description' => $description ]); $processedBrands[] = $name; } }
Output for 7.1.26 - 7.1.33, 7.2.17 - 7.2.33, 7.3.0 - 7.3.31, 7.4.0 - 7.4.32, 8.0.0 - 8.0.12, 8.0.14 - 8.0.30, 8.1.0 - 8.1.28, 8.2.0 - 8.2.18, 8.3.0 - 8.3.6
Fatal error: Uncaught RuntimeException: SplFileObject::__construct(): open_basedir restriction in effect. File(import_mmt_20140701.csv) is not within the allowed path(s): (/tmp:/in:/etc) in /in/MJ6GM:2 Stack trace: #0 /in/MJ6GM(2): SplFileObject->__construct('import_mmt_2014...', 'r') #1 {main} thrown in /in/MJ6GM on line 2
Process exited with code 255.
Output for 8.0.13
Fatal error: Uncaught RuntimeException: SplFileObject::__construct(import_mmt_20140701.csv): Failed to open stream: No such file or directory in /in/MJ6GM:2 Stack trace: #0 /in/MJ6GM(2): SplFileObject->__construct('import_mmt_2014...', 'r') #1 {main} thrown in /in/MJ6GM on line 2
Process exited with code 255.
Output for 7.0.0 - 7.0.20, 7.1.0 - 7.1.10, 7.2.0, 7.3.32 - 7.3.33, 7.4.33
Fatal error: Uncaught RuntimeException: SplFileObject::__construct(import_mmt_20140701.csv): failed to open stream: No such file or directory in /in/MJ6GM:2 Stack trace: #0 /in/MJ6GM(2): SplFileObject->__construct('import_mmt_2014...', 'r') #1 {main} thrown in /in/MJ6GM on line 2
Process exited with code 255.
Output for 7.1.20, 7.2.6
Fatal error: Uncaught RuntimeException: SplFileObject::__construct(): open_basedir restriction in effect. File(import_mmt_20140701.csv) is not within the allowed path(s): (/tmp:/in) in /in/MJ6GM:2 Stack trace: #0 /in/MJ6GM(2): SplFileObject->__construct('import_mmt_2014...', 'r') #1 {main} thrown in /in/MJ6GM on line 2
Process exited with code 255.
Output for 5.4.0 - 5.4.45, 5.5.0 - 5.5.38, 5.6.0 - 5.6.28
Fatal error: Uncaught exception 'RuntimeException' with message 'SplFileObject::__construct(import_mmt_20140701.csv): failed to open stream: No such file or directory' in /in/MJ6GM:2 Stack trace: #0 /in/MJ6GM(2): SplFileObject->__construct('import_mmt_2014...', 'r') #1 {main} thrown in /in/MJ6GM on line 2
Process exited with code 255.
Output for 5.3.0 - 5.3.29
Parse error: syntax error, unexpected '[' in /in/MJ6GM on line 3
Process exited with code 255.
Output for 4.4.2 - 4.4.9, 5.1.0 - 5.1.6, 5.2.0 - 5.2.17
Warning: Unexpected character in input: '\' (ASCII=92) state=1 in /in/MJ6GM on line 2 Parse error: syntax error, unexpected '[' in /in/MJ6GM on line 3
Process exited with code 255.
Output for 4.3.0 - 4.3.1, 4.3.5 - 4.3.11, 4.4.0 - 4.4.1, 5.0.0 - 5.0.5
Warning: Unexpected character in input: '\' (ASCII=92) state=1 in /in/MJ6GM on line 2 Parse error: parse error, unexpected '[' in /in/MJ6GM on line 3
Process exited with code 255.
Output for 4.3.2 - 4.3.4
Warning: Unexpected character in input: '\' (ASCII=92) state=1 in /in/MJ6GM on line 2 Parse error: parse error in /in/MJ6GM on line 3
Process exited with code 255.

preferences:
270.91 ms | 401 KiB | 385 Q