从CSV文件中读取数据

时间:2022-05-03 10:06:55

可以用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