从CSV文件中读取数据

可以用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
posted @ 2011-05-25 22:14  ywxgod  阅读(5939)  评论(0编辑  收藏  举报