123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108 |
- <?php
- /* For licensing terms, see /license.txt */
- /**
- * This class provides some functions which can be used when importing data from
- * external files into Chamilo.
- * @package chamilo.library
- */
- /**
- * Class
- * @package chamilo.library
- */
- class Import {
- /**
- *
- * @param string $path
- * @return \CsvReader
- */
- static function csv_reader($path)
- {
- return new CsvReader($path);
- }
- /**
- * Reads a CSV-file into an array. The first line of the CSV-file should contain the array-keys.
- * The encoding of the input file is tried to be detected.
- * The elements of the returned array are encoded in the system encoding.
- * Example:
- * FirstName;LastName;Email
- * John;Doe;john.doe@mail.com
- * Adam;Adams;adam@mail.com
- * returns
- * $result [0]['FirstName'] = 'John';
- * $result [0]['LastName'] = 'Doe';
- * $result [0]['Email'] = 'john.doe@mail. com';
- * $result [1]['FirstName'] = 'Adam';
- * ...
- * @param string $filename The path to the CSV-file which should be imported.
- * @return array Returns an array (in the system encoding) that contains all data from the CSV-file.
- *
- *
- * @deprecated use cvs_reader instead
- */
- static function csv_to_array($filename, $csv_order = 'vertical') {
- $result = array();
- // Encoding detection.
- $handle = fopen($filename, 'r');
- if ($handle === false) {
- return $result;
- }
- $buffer = array();
- $i = 0;
- while (!feof($handle) && $i < 200) {
- // We assume that 200 lines are enough for encoding detection.
- $buffer[] = fgets($handle);
- $i++;
- }
- fclose($handle);
- $buffer = implode("\n", $buffer);
- $from_encoding = api_detect_encoding($buffer);
- unset($buffer);
- // Reading the file, parsing and importing csv data.
- $handle = fopen($filename, 'r');
- if ($handle === false) {
- return $result;
- }
- if ($csv_order == 'vertical') {
- $keys = Text::api_fgetcsv($handle, null, ';');
- foreach ($keys as $key => &$key_value) {
- $key_value = api_to_system_encoding($key_value, $from_encoding);
- }
- }
- while (($row_tmp = Text::api_fgetcsv($handle, null, ';')) !== false) {
- $row = array();
- // Avoid empty lines in csv
- if (is_array($row_tmp) && count($row_tmp) > 0 && $row_tmp[0] != '') {
- if (!is_null($row_tmp[0])) {
- if ($csv_order == 'vertical') {
- foreach ($row_tmp as $index => $value) {
- $row[$keys[$index]] = api_to_system_encoding($value, $from_encoding);
- }
- } else {
- $first = null;
- $count = 1;
- foreach ($row_tmp as $index => $value) {
- if ($count == 1) {
- $first = $value;
- } else {
- $row[$first][] = api_to_system_encoding($value, $from_encoding);
- }
- $count++;
- }
- }
- $result[] = $row;
- }
- }
- }
- fclose($handle);
- return $result;
- }
- }
|