1

嗨,我对 php 完全陌生,想通过 php 将来自 javascript 的 json 对象存储为 .csv 文件。

我有一个 JSON 对象,在名为 Logger.json 的文件中定义:

{
    "Name": "Dummy",
    "Uhrzeit": "1234",
    "Speed": "100",
    "Level": "11",
    "Szenen": {

    }
}

通过 $.getJson 读取文件后,我向对象添加了一些属性。Logger.php 现在接收内容(首先它一直是空的,因为我错过json_decode($_POST['data'], true);了最后的布尔值 true),但存储的 .csv 只包含(“数组,数组”)。

我还尝试了其他内容类型,只发送 jsonText(不带 data=)或对象 obj 本身。任何想法为什么它不起作用?谢谢!

$.getJSON('xml/Logger.json', function(obj) {

        //add new scene:
        obj.Szenen["144"] = {};
        obj.Szenen["144"]["happy"] = {};
        obj.Szenen["144"]["happy"].type = "right";
        obj.Szenen["144"]["happy"].collected = "0";
        obj.Szenen["144"]["sad"] = {};
        obj.Szenen["144"]["sad"].type = "false";
        obj.Szenen["144"]["sad"].collected = "0";
        obj.Szenen["144"]["angry"] = {};
        obj.Szenen["144"]["angry"].type = "false";
        obj.Szenen["144"]["angry"].collected = "0";
        obj.Szenen["200"] = {};
        obj.Szenen["200"]["happy"] = {};
        obj.Szenen["200"]["happy"].type = "right";

        console.log(obj);

        var jsonText = JSON.stringify(obj);

        var request= new XMLHttpRequest();
        request.open("POST", "http://localhost/logger.php")
        request.setRequestHeader("Content-type", "application/x-www-form-urlencoded", true)


var data = "data="+jsonText;
request.send(data);

我的 logger.php 看起来像这样:

<?php

 $values = json_decode($_POST['data'], true);
 store($values);

function store($data) {
    $file = 'logs/UserLogging';

    $filename = $file."_".date("d-m-Y_H-i",time()).".csv";

    $fp = fopen($filename, 'w');
    foreach($data as $line){
        //$val = explode(",",$line);
        fputcsv($fp, $line);
    }    
    fclose($fp);    
}

?>

编辑: .csv 应该看起来像这样(但如果像“Name”或“Uhrzeit”这样的键也会出现在输出中,那将是完美的):

Dummy,1234,100,11;
144,happy,right,0,sad,false,0,angry,false,0;
200,happy,right ...
4

1 回答 1

1

您的fputcsv 语法不正确 - 参数 2 必须是一个数组(被分解为逗号分隔的值)。

例如,fputcsv([a,b,c])将写入a,b,c文件后跟换行符。

您只需要将 JSON 解码的对象转换为数组。在不知道您想要的格式的情况下,这是一个简单的示例:

...(在函数中store)...

$fp = fopen($filename, 'w');
fputcsv($fp, (array)$data);
fclose($fp);

它存储了顶级键的 CSV。

于 2013-09-20T13:45:11.170 回答