слияние csv данные с php?

Есть многие CSV файл как следующее: a.csv , b.csv , aab.csv и т.д.

Они держат ту же самую колонку и заголовок. Теперь я хочу поместить все csv данные в whole.csv . Только с одним заголовком. Как я могу сделать это?

a.csv data:

header1 title post.....

test   who  posand

b.csv data:

header1 title post.....

head   she  pnow

и т.д.....

whole.csv будет содержать все csv данные. например:

header1 title post.....

head   she  pnow
test   who  posand

Я попробовал следующий code.but не, добираются, я хочу:

$csvs = glob("*.csv");

foreach($csvs as $csv) {
  $row = 1;
  if (($handle = fopen($csv, "r")) !== FALSE) {
    while (($data = fgetcsv($handle, 1000, ",")) !== FALSE) {
      $fp = fopen("whole.csv", 'w');
      fputcsv($fp, $data);
      $row++;
    }
    fclose($handle);
  }
}

Я поместил все файлы CSV в тот же самый справочник.

1
добавлено отредактировано
Просмотры: 1
de

2 ответы

Для каждого входного файла CSV вы открываете проистекающий файл CSV в режиме записи:

$fp = fopen("whole.csv", 'w');

который вытирает содержание whole.csv !!

Необходимо открыть whole.csv файл только однажды вне петли и продолжать писать в него.

$csvs = glob("*.csv");
$fp   = fopen("whole.csv", 'w');

foreach($csvs as $csv) {
  $row = 1;
  if (($handle = fopen($csv, "r")) !== FALSE) {
    while (($data = fgetcsv($handle, 1000, ",")) !== FALSE) {
      fputcsv($fp, $data);
      $row++;
    }
    fclose($handle);
  }
}
1
добавлено
Сколько линии в тех файлах CSV? Каков их размер?
добавлено автор j0k, источник
добавлено автор hehe, источник
есть ли в коде некоторая ошибка. это показывает Фатальную ошибку: Максимальное время выполнения 30 секунд превысило меня
добавлено автор hehe, источник
я только проверяю его только с четырьмя файлами CSV.
добавлено автор hehe, источник

Взгляните на file_put_contents .

Вы открыли бы каждый файл CSV, затем использовать file_put_contents проходящий whole.csv как $filename параметр, дескриптор файла как $data параметр и используют FILE_APPEND флаг, чтобы сказать ему прилагать содержание вместо переписывания.

0
добавлено