php使用python脚本文件内容的方法:1、使用system()和exec()两个函数调用外部程序,打印命令执行输出功能;2、使用“>>符号将命令的输出重新定位到另一个文件或流中,以防止php页面堵塞。
上次我自动翻译用户反馈,写了一个python脚本,把日语用户反馈翻译成中文。虽然效果还可以,但其他不懂python的童鞋是不能用的,所以我建立了一个web服务,让其他人可以通过网页访问查询。使用apache服务,具体环境(LAMP)不细说搭建,主要分享php调用python脚本后台运行的处理。
1. 如何调用外部程序?
首先要解决的问题是php如何调用python脚本,在php中调用外部程序主要有两个函数,system和exec。
system()原型:string system(string command [, int $return_var])。
system函数本身具有打印命令执行输出的功能,也就是说,程序中的输出可以显示在PHP页面上。如果程序成功执行,system的返回值是程序输出的最后一行。如果执行失败,返回false。第二个参数是可选的,用于获得命令执行后的状态代码。0表示外部程序成功调用,1表示调用失败。
<?php echo("Congratulations!\n"); $cmd=system("pythonfeedback.py20141010",$ret); echo("retis$ret"); ?>
exec()原型:string exec (string command [, string array [, int return_var]])
exec ()函数类似于system(),也执行给定的命令,但不输出结果,而是返回结果的最后一行。虽然它只返回命令结果的最后一行,但它使用第二个参数aray 获得完整结果的方法是将结果逐行添加到array的结尾。只有在指定第二个参数时,才能使用第三个参数来获得命令执行的状态代码。
<?php exec("pythonfeedback.py20141010",$array,$ret); echo("result:$array"); echo("retis$ret"); ?>
由于调用的python翻译脚本可能需要多次要求百度翻译api,因此偶尔需要很长时间才能将此命令放在系统的后台执行,以防止php页面堵塞或加班。解决办法是将命令的输出重定向到另一个文件或流中,重定向符">>"清空原文件内容后,写入新内容,“>在文件末尾添加新内容。
<?php system("pythonfeedback.py20141010>/tmp/null&"); //system("pythonfeedback.py20141010>>tmp.txt&"); ?>
2. php 如何知道python脚本在后台的运行结束
一开始,我的做法是在python脚本运行前写一个tmp.txt,然后在php中循环判断tmp.txt文件是否生成,但结果可想而知,php被阻塞...因此,ajax被用来实现网页的异步更新。checkresultt.php脚本是循环判断tmp.为了判断python脚本是否运行结束,txt文件是否生成。
<scripttype="text/javascript"> functioncheckResult() { varxmlhttp; if(window.XMLHttpRequest){ ///codeforIE7+,Firefox,Chrome,Opera,Safari xmlhttp=newXMLHttpRequest(); } else{ ///codeforIE6,IE5 xmlhttp=newActiveXObject("Microsoft.XMLHTTP"); } xmlhttp.onreadystatechange=function(){ if(xmlhttp.readyState==4&&xmlhttp.status==200){ document.getElementById("txtHint").innerHTML=xmlhttp.responseText; } } xmlhttp.open("GET","checkResult.php?t="+Math.random(),true); xmlhttp.send(); } </script> <body> ... <pid='txtHint'> ... </body>
checkResult.php脚本
<?php $timeflag=True; while($timeflag){ sleep(3); if(file_exists("tmp.txt")){ $timeflag=False; $response="Success!!!"; break; } } echo$response; ?>
最终的结果相当可观,这是我第一次使用ajax,感觉很好~
推荐课程:Flask实战视频教程