PHP写CSV文件,JavaScript读json文件中文乱码问题


前言

第一次使用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";  //C()为传值函数
    $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',   //这里的python就是你本机中python.exe的文件位置

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);  //对中文处理,进行转码GB2312->UTF-8
echo $coords_string;  //这就是读好的json字符串啦

四、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;  //这一步非常重要,要不然你就会收获一个报错,JSON.parse():json字符串转为JavaScript对象,但这个转出来的对象类型在不同情况下不一样,所以需要一个三目表达式来处理有中文的情况

    }
});

到此顺利结束啦,回头过来看真是非常简单呢,但第一次接触PHP的我可是甘了一天才弄出来哦,特此记录。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值