php 生成csv文件并提示保存

我想编写一个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 );

?>
我用正则表达式解决问题了,但是如果在用户输入信息的时候输入'单引号的话,用excel打开的时候要求显示这个单引号,例如输入'77用excel显示的时候也是'77我现在用的正则表达式将"和,都过滤掉了,但是用excel显示的时候,对于输入的'77只显示77,请问怎么也能让'也在excel中表示呢?我的正则 $value = preg_replace("/[\"|,]/","",$value);

 <?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;
?>
温馨提示:答案为网友推荐,仅供参考
第1个回答  2009-02-26
照你这样做,还得同时让用户上传以前的csv文件呀

或者你在服务器上保存不同用户最新的csv文件也是可行的本回答被提问者采纳
第2个回答  2009-02-27
csv文件的格式你应该清楚吧.

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

至于过滤引号,如果没有专门的函数就自己写一个,可以一个字符一个字符读, 碰到引号跳过.
第3个回答  2009-02-27
你这句 fwrite($handle,$data."\r\n"); 就已经把$data写到文件了啊
接着下面再fgets($handle)的话是读不到内容的,因为这时指针在文件的最后
你应该在fwrite后fclose,这样文件就保存了
输出的话不用再读文件,所有数据都在$data里啊,按csv格式输出就行
另外建议你用fputcsv函数,不用你过滤和转义字符
给个例子:
<?php
$list = array (
'aaa,bbb,ccc,dddd',
'123,456,789',
'"aaa","bbb"'
);
$fp = fopen('php://output', 'w');

foreach ($list as $line) {
fputcsv($fp, split(',', $line));
}
fclose($fp);
?>
相似回答