php资料
这是稍微有经验的phper 都会采用如下方式来解决问题1. 看错误输出, 从输出项 反查源码,在源码处上下文加入调试代码,代码可以是最简单的
$debuglineno = __LINE__;
die($debuglineno);
2. 根据错误输出 Google 之 或者 百度一下
PHP定时执行任务的实现
config.php
<?php
return 1;
?>
cron.php
ignore_user_abort();//关掉浏览器,PHP脚本也可以继续执行.
set_time_limit(0);// 通过set_time_limit(0)可以让程序无限制的执行下去
$interval=60*30;// 每隔半小时运行
do{
$run = include 'config.php';
if(!$run) die('process abort');
//这里是你要执行的代码
sleep($interval);// 等待5分钟
}while(true);
主要改变config.php中return 0就可以实现了控制这个cron,
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;
fclose($file);
?>
在实际工作中,很多时候需要把网站上的一些数据下载到CSV文件里,方便以后查看。
亦或者是用CSV进行一些批量的上传工作。
这个时候我们就需要对CSV进行读写操作。
1.CSV的读取操作
view plaincopy to clipboardprint?
[*]<?php
[*]
$file =
fopen('D:/file/file.csv','r');
[*]
while ($data =
fgetcsv($file)) {//每次读取CSV里面的一行内容
[*]
print_r($data);
//此为一个数组,要获得每一个数据,访问数组下标即可
[*] }
[*]
fclose($file);
[*]?>
<?php$file = fopen('D:/file/file.csv','r');while ($data = fgetcsv($file)) { //每次读取CSV里面的一行内容print_r($data); //此为一个数组,要获得每一个数据,访问数组下标即可}fclose($file);?>
2.CSV的写入操作
view plaincopy to clipboardprint?
[*]<?php
[*]
$fp =
fopen('d:/file/file.csv',
'w');
[*]
fputcsv($fp,array('aaa','bbb','cccc'));
[*]
fputcsv($fp,array('mmm','yyy','haha'));//fputcsv可以用数组循环的方式进行实现
[*]
fclose($fp);
[*]?>
<?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(下载功能)
view plaincopy to clipboardprint?
[*]<?php
[*]
header("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";
[*]?>
<?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销毁变量并释放内存
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()也是为了在变量不起作用时,释放内存。
页:
[1]