2. 根据错误输出 Google 之 或者 百度一下
php对csv文件的读取,写入,输出下载操作
<?php
$file = fopen('text.csv','r');
while ($data = fgetcsv($file)) { //每次读取CSV里面的一行内容
//print_r($data); //此为一个数组,要获得每一个数据,访问数组下标即可
$goods_list[] = $data;
}
//print_r($goods_list);
echo $goods_list[0][1];
fclose($file);
?>
在实际工作中,很多时候需要把网站上的一些数据下载到CSV文件里,方便以后查看。
亦或者是用CSV进行一些批量的上传工作。
这个时候我们就需要对CSV进行读写操作。
1.CSV的读取操作
<?php$file = fopen('D:/file/file.csv','r');while ($data = fgetcsv($file)) { //每次读取CSV里面的一行内容print_r($data); //此为一个数组,要获得每一个数据,访问数组下标即可}fclose($file);?>
2.CSV的写入操作
<?php$fp = fopen('d:/file/file.csv', 'w');fputcsv($fp,array('aaa','bbb','cccc'));fputcsv($fp,array('mmm','yyy','haha')); //fputcsv可以用数组循环的方式进行实现fclose($fp);?>
3.输出CSV(下载功能)
<?phpheader("Content-Type: text/csv");header("Content-Disposition: attachment; filename=test.csv");header('Cache-Control:must-revalidate,post-check=0,pre-check=0');header('Expires:0');header('Pragma:public');echo "id,areaCode,areaName\n";echo "1,cn,china\n";echo "2,us,America\n";?>
PHP的unset()函数用来清除、销毁变量,不用的变量,我们可以用unset()将它销毁。但是某些时候,用unset()却无法达到销毁变量占用的内存!我们先看一个例子:
- <?php
- $s=str_repeat('1',255);//产生由255个1组成的字符串
- $m=memory_get_usage();//获取当前占用内存
- unset($s);
- $mm=memory_get_usage();//unset()后再查看当前占用内存
- echo$m-$mm;
- ?>
最后输出unset()之前占用内存减去unset()之后占用内存,如果是正数,那么说明unset($s)已经将$s从内存中销毁(或者说,unset()之后内存占用减少了),可是我在PHP5和windows平台下,得到的结果是:-48。这是否可以说明,unset($s)并没有起到销毁变量$s所占用内存的作用呢?我们再作下面的例子:
- <?php
- $s=str_repeat('1',256);//产生由256个1组成的字符串
- $m=memory_get_usage();//获取当前占用内存
- unset($s);
- $mm=memory_get_usage();//unset()后再查看当前占用内存
- echo$m-$mm;
- ?>
这个例子,和上面的例子几乎相同,唯一的不同是,$s由256个1组成,即比第一个例子多了一个1,得到结果是:224。这是否可以说明,unset($s)已经将$s所占用的内存销毁了?
通过上面两个例子,我们可以得出以下结论:结论一、unset()函数只能在变量值占用内存空间超过256字节时才会释放内存空间。
那么是不是只要变量值超过256,使用unset就可以释放内存空间呢?我们再通过一个例子来测试一下:
- <?php
- $s=str_repeat('1',256);//这和第二个例子完全相同
- $p=&$s;
- $m=memory_get_usage();
- unset($s);//销毁$s
- $mm=memory_get_usage();
- echo$p.'<br/>';
- echo$m-$mm;
- ?>
刷新页面,我们看到第一行有256个1,第二行是-48,按理说我们已经销毁了$s,而$p只是引用$s的变量,应该是没有内容了,另外,unset($s)后内存占用却比unset()前增加了!现在我们再做以下的例子:
- <?php
- $s=str_repeat('1',256);//这和第二个例子完全相同
- $p=&$s;
- $m=memory_get_usage();
- $s=null;//设置$s为null
- $mm=memory_get_usage();
- echo$p.'<br/>';
- echo$m-$mm;
- ?>
现在刷新页面,我们看到,输出$p已经是没有内容了,unset()前后内存占用量之差是224,即已经清除了变量占用的内存。本例中的$s=null也可以换成unset(),如下:
- <?php
- $s=str_repeat('1',256);//这和第二个例子完全相同
- $p=&$s;
- $m=memory_get_usage();
- unset($s);//销毁$s
- unset($p);
- $mm=memory_get_usage();
- echo$p.'<br/>';
- echo$m-$mm;
- ?>
我们将$s和$p都使用unset()销毁,这时再看内存占用量之差也是224,说明这样也可以释放内存。那么,我们可以得到另外一条结论:结论二、只有当指向该变量的所有变量(如引用变量)都被销毁后,才会释放内存。
相信经过本文的例子后,大家应该对unset()有所了解了,最起码,本人用unset()也是为了在变量不起作用时,释放内存。