Войти через VK Войти через FB Войти через Google Войти через Яндекс
Поиск по сайту
Стандартная работа с CSV-файлами на PHP
Часто возникает задача переноса Excel-таблиц на Web-страницы сайта. На первый взгляд нет ничего проще, - достаточно сохранить файл из Excel в формате html. Но при ближайшем рассмотрении получившегося монстра приходишь в ужас и отказываешься от подобной идеи. Поэтому для переноса Excel-таблиц на сайт их предварительно сохраняют как CSV-файл, который разбирают и динамически формируют HTML-таблицу. Так как CSV-файлы, всё-таки генерирует Excel, этот формат тоже не проблемный. Ячейки разделяются точкой с запятой и их нужно различать от точек с запятой, которые входят в состав текста ячейки. Сама ячейка, содержащая текстовые данные, обрамлена двойными кавычками, если в ячейке встречается символ двойных кавычек – они удваиваются.
$f = fopen("file.csv", "rt") or die("Ошибка!");
for ($i=0; ($data=fgetcsv($f,1000,";"))!==false; $i++) {
$num = count($data);
echo "<h3>Строка номер $i (полей: $num):</h3>";
for ($c=0; $c<$num; $c++)
print "[$c]: $data[$c]<br>";
}
fclose($f);
Смотри также описание функции fgetcsv().
Класс работы с CSV-файлами на PHP
class File_FGetCSV {
var $VERSION = "1.01";
function fgetcsv($f, $length, $d=",", $q='"') {
$list = [];
$st = fgets($f, $length);
if ($st === false) return $st;
if (trim($st) === "") return [];
while ($st !== "" && $st !== false) {
if ($st[0] !== $q) {
# Non-quoted.
list ($field) = explode($d, $st, 2);
$st = substr($st, strlen($field)+strlen($d));
} else {
# Quoted field.
$st = substr($st, 1);
$field = "";
while (1) {
# Find until finishing quote (EXCLUDING) or eol (including)
preg_match("/^((?:[^$q]+|$q$q)*)/sx", $st, $p);
$part = $p[1];
$partlen = strlen($part);
$st = substr($st, strlen($p[0]));
$field .= str_replace($q.$q, $q, $part);
if (strlen($st) && $st[0] === $q) {
# Found finishing quote.
list ($dummy) = explode($d, $st, 2);
$st = substr($st, strlen($dummy)+strlen($d));
break;
} else {
# No finishing quote - newline.
$st = fgets($f, $length);
}
}
}
$list[] = $field;
}
return $list;
}
function fputcsv($f, $list, $d=",", $q='"') {
$line = "";
foreach ($list as $field) {
# remove any windows new lines,
# as they interfere with the parsing at the other end
$field = str_replace("\r\n", "\n", $field);
# if a deliminator char, a double quote char or a newline
# are in the field, add quotes
if(preg_match("/[$d$q\n\r]/", $field)) {
$field = $q.str_replace($q, $q.$q, $field).$q;
}
$line .= $field.$d;
}
# strip the last deliminator
$line = substr($line, 0, -1);
# add the newline
$line .= "\n";
# we don't care if the file pointer is invalid,
# let fputs take care of it
return fputs($f, $line);
}
}
Аналог функции fgetcsv
function fgetcsv($f, $length, $d=",", $q='"') {
$list = [];
$st = fgets($f, $length);
if ($st === false) return $st;
if (trim($st) === "") return [];
while ($st !== "" && $st !== false) {
if ($st[0] !== $q) {
# Non-quoted.
list ($field) = explode($d, $st, 2);
$st = substr($st, strlen($field)+strlen($d));
} else {
# Quoted field.
$st = substr($st, 1);
$field = "";
while (1) {
# Find until finishing quote (EXCLUDING) or eol (including)
preg_match("/^((?:[^$q]+|$q$q)*)/sx", $st, $p);
$part = $p[1];
$partlen = strlen($part);
$st = substr($st, strlen($p[0]));
$field .= str_replace($q.$q, $q, $part);
if (strlen($st) && $st[0] === $q) {
# Found finishing quote.
list ($dummy) = explode($d, $st, 2);
$st = substr($st, strlen($dummy)+strlen($d));
break;
} else {
# No finishing quote - newline.
$st = fgets($f, $length);
}
}
}
$list[] = $field;
}
return $list;
}
Пример ручного разбора CSV на PHP
my $v = '"aa\\";a\\\\";e;1;;m;9.2;';
my @a;
while ($v =~ /"([^"\\]*(\\.[^"\\]*)*)";?|([^;]+);?|;/g) {
push (@a, defined($1) ? $1 : $3);
}
push (@a, undef) if $v =~ /;$/;
print @a+0,"\n";
print "@a";
Если возникают проблемы с распознаванием конца строки в CSV-файле используйте команду:
ini_set('auto_detect_line_endings',TRUE);
Смотри также описание функции fgetcsv().
.
Прокомментировать/Отблагодарить