php输出、写入csv

1.首先会使用 php中的header()的用法

这里可以参考w3school中的PHP header() 函数php使headerhttp

在任何实际的输出被发送之前都要调用 header() 函数。

下面就以php输出csv例。

 

1.定义header()头部输出格式

header("Content-type:application/vnd.ms-excel");  //定义输出的文件类型

header(“content-Disposition:filename=downloaded.pdf”);  //定义输出的文件名,也就是设置一个下载类型,下载的时候对文件从新命名

 

<?php
header("Content-type:application/vnd.ms-excel");
header("content-Disposition:filename=downloaded.pdf ");

echo"1\t 2\t 3\n"; //其中 \t 是空白 ,\n是回车 (编码规范 不能直接输出)
echo"1\t 2\t 3\n";
echo"1\t 2\t 3\n";


?>

 

这时候就可以打开这个php文件,就会提示下载。

 

也可以以table表格的方式输出;


<?php
  
header("Content-type:application/vnd.ms-excel ");
 
header("content-Disposition:filename=downloaded.pdf");
?>
  
<table>
    
<tr>
      
<td>t00td><td>t01td><td>t02td>
    
tr>
    
<tr>
      
<td>t10td><td>t11td><td>t12td>
    
tr>
    
<tr>
      
<td>t20td><td>t21td><td>t22td>
    
tr>
  
table>

 

CSV的写入操作:

fputcsv()的使用可参考.

 

  $fp = fopen('f:/file.csv', 'w');
      fputcsv(
$fp,array('aaa','bbb','cccc'));
      fputcsv(
$fp,array('mmm','yyy','haha'));   //fputcsv()可以用数组循环的方式进行实现
       fclose($fp);

PHP fgetcsv() 函数

定义和用法

fgetcsv() 函数从文件指针中读入一行并解析 CSV 字段。

fgets() 类似,不同的是 fgetcsv() 解析读入的行并找出 CSV 格式的字段,然后返回一个包含这些字段的数组。

fgetcsv() 出错时返回 FALSE,包括碰到文件结束时。

注释:PHP 4.3.5 起,fgetcsv() 的操作是二进制安全的。

语法

fgetcsv(file,length,separator,enclosure)
参数 描述
file 必需。规定要检查的文件。
length

可选。规定行的最大长度。必须大于 CVS 文件内最长的一行。

PHP 5 中该参数是可选的。在 PHP 5 之前是必需的。

如果忽略(在 PHP 5.0.4 以后的版本中设为 0)该参数的话,那么长度就没有限制,不过可能会影响执行效率。

separator 可选。设置字段分界符(只允许一个字符),默认值为逗号。
enclosure

可选。设置字段环绕符(只允许一个字符),默认值为双引号。

该参数是在 PHP 4.3.0 中添加的。

提示和注释

注释:CSV 文件中的空行将被返回为一个包含有单个 null 字段的数组,不会被当成错误。

注释:该函数对区域设置是敏感的。比如说 LANG 设为 en_US.UTF-8 的话,单字节编码的文件就会出现读取错误。

注释:如果碰到 PHP 在读取文件时不能识别 Macintosh 文件的行结束符,可以激活 auto_detect_line_endings 运行时配置选项。

例子

例子 1

<?php

$file = fopen("contacts.csv","r");
print_r(fgetcsv($file));
fclose($file);

?>

CSV 文件:

George, John, Thomas, USA
James, Adrew, Martin, USA

输出类似:

Array 
( 
[0] => George
[1] => John 
[2] => Thomas
[3] => USA
)

例子 2

<?php

$file = fopen("contacts.csv","r");

while(! feof($file))
  {
  print_r(fgetcsv($file));
  }

fclose($file);

?> 

CSV 文件:

George, John, Thomas, USA
James, Adrew, Martin, USA

输出类似:

Array 
( 
[0] => George
[1] => John 
[2] => Thomas
[3] => USA

Array
(
[0] => James
[1] => Adrew
[2] => Martin
[3] => USA
)

有话要说