前言
第一次使用PHP读写中文文件血泪史: 项目背景:PHP后端把前端用户查询的结果写入CSV文件,然后调用python程序读取刚才的CSV文件并进行处理,然后将处理结果写入json文件;然后PHP读取该json文件并将json字符串传给前端进行显示。(PS:这一段是不是很像绕口令?!反正我是被绕进去了)
提示:以下是本篇文章正文内容
一、PHP写入CSV文件
PHP写入CSV文件,默认编码格式是gbk,这就导致我们打开CSV文件时中文会乱码,需要改为utf-8
<?php
$path = C('SURNAME_MAP_PATH')."./address.csv";
$file = fopen($path,'w');
fprintf($file, chr(0xEF).chr(0xBB).chr(0xBF));
$list = array($data['province'],$data['city']);
fputcsv($file,$list);
?>
二、调用Python程序
1.在PHP的config.php中添加一个变量,该变量指向你本机的Python解释器
代码如下(示例):
'PYTHON_PATH'=>'D:\Software\Anaconda\envs\myproject\python',
2.把需要执行的python程序放在PHP的项目文件下,然后执行
代码如下(示例):
exec(C('PYTHON_PATH')." ./Public/python/main.py",$out,$res);
是不是很简单?!
三、PHP读取json文件
上一步的python程序已经写好了json文件,我们现在就要把它读出来
$path = C('SURNAME_MAP_PATH')."./coords.json";
$coords =file_get_contents($path);
$coords_string = iconv('GB2312','UTF-8',$coords);
echo $coords_string;
四、JavaScript解析json字符串
使用Ajax方法进行接收
$.ajax({
type: "POST",
url: url1,
dataType: 'json',
success: function (cdata) {
$.AMUI.progress.done();
console.log("cdata....",cdata)
geoCoordMap =typeof cdata=='String'?JSON.parse(cdata):cdata;
}
});
到此顺利结束啦,回头过来看真是非常简单呢,但第一次接触PHP的我可是甘了一天才弄出来哦,特此记录。
|