php 生成csv文件并提示保存

来源:百度知道 编辑:UC知道 时间:2024/06/21 07:33:03
我想编写一个csv文件输出的程序,用户输入相关信息之后,点击按钮提示用户保存路径,输出的文件类型是“.csv”的,该程序不使用数据库,只是对文本进行操作,也就是用户输入的信息存入文本“2009-02.csv中”,之后用户再输入信息,还是存储在该文本中,进行换行。
一个月进行一次新文本的更新,如何控制用户输入信息和csv文件的格式呢?
例如
”a”,”b”,”c”,”d”,”e”
”1”,”2”,”3”,”4”,”5”
”6”,”7”,”8”,”9”,”0”
我下面写的代码输出的只有“姓名,住所,电话,说明”,如何让用户输入的信息存储在文本中呢?请高手指教,成功之后再加分
<?php

mb_http_output("SJIS");
header("Content-type:application/vnd.ms-excel");
header("Content-Disposition:attachment;filename=2009-01.csv");
echo "姓名,住所,电话,说明";

session_start();

$_SESSION['data']=$_POST;

$handle=fopen("2009-01.csv","a+");

$data=join(",",$_SESSION['data']);

fwrite($handle,$data."\r\n");
while($str = fgets($handle)){

$str = fgets($handle);
echo ($str? ",":"");

}
fclose($handle );

 <?php
 //文件名
 $filename="test.csv";
 
 //数据(具体的根据需要做处理,如果是从数据库查询,原理与此类似,只需设置好写入格式和数据即可。
 $data="测试csv";

//设置header
header("Content-type:text/csv");
header("Content-Disposition:attachment;filename=".$filename);
header('Cache-Control:must-revalidate,post-check=0,pre-check=0');
header('Expires:0'); header('Pragma:public');
echo $data;
?>

照你这样做,还得同时让用户上传以前的csv文件呀

或者你在服务器上保存不同用户最新的csv文件也是可行的

csv文件的格式你应该清楚吧.

是用逗号分隔每行的几个数据的.
存的时候写一个数据,再写个逗号,再写一个数据,...
写完一行数据,再换行就行了.

至于过滤引号,如果没有专门的函数就自己写一个,可以一个字符一个字符读, 碰到引号跳过.

你这句 fwrite($handle,$data."\r\n"); 就已经把$data写到文件了啊
接着下面再fgets($handle)的话是读不到内容的,因为这时指针在文件的最后
你应该在fwrite后fclose,这样文件就保存了
输出的话不用再读文件,所有数据都在$data里啊,按csv格式输出就行
另外建议你用fputcsv函数,不用你过滤和转义字符