可以用fgetcsv(file,length,separator,enclosure)函数读取csv文件。
fgetcsv的参数说明如下:
file:需要读取的csv文件,此参数是必需的。
length:表示大于csv文件中最长的行的长度的值。php5之前是必需参数。在php5中是可选参数,如果不设置此参数或者将其设为0,php将会读取
一整行的数据。如果行的长度超过8192个字节时,应该将length值设定一个数,而不是让php自动去计算行的长度。
separator:指定数据的分隔符,默认是逗号,如果指定为“;”,那么fgetcsv函数将按照“;”来解析行数据。
fgetcsv的返回值:
根据file的一行数据,返回一个数组。如果读取文件出错,则返回false。到达文件尾部时,也返回false。
下面是一个读取test.csv文件的例子。
$file = fopen('test.csv','r') or die("Can't open file test.csv");
$color="#ff0000";
print '<table border=0>';
while($csv_line=fgetcsv($file))
{
print "<tr>";
$len = count($csv_line);
for($i=0;$i<$len;$i++)
{
if($i%2==0)$color="#cccccc";
else $color="#999999";
print '<td bgcolor='.$color.'>'.htmlentities($csv_line[$i]).'</td>';
}
print "</tr>";
}
print '</table>';
fclose($file) or die("Can't close file test.csv!");
最后的输出结果:
111 | sdfsd | sdds | 43344 | rrrr |
sssssssss | gdfgfd | 232323 | wwewe | dsfds |
fgfg | e4343 | dsfds | w2332 | xcvxc |
11212 | 2323 | 344343 | 344343 | rerreer |
fds | 43344444 | 33333333 | ttttttt | gggggggggggg |
kdfs | dsfdsfds | wewewe | sdsdddddddd | wwwwwwwwwww |