簡體   English   中英

如何將CSV文件中的某些行放入JSON對象中的JSON數組中? (PHP)

[英]How can I put certain rows from CSV file into JSON arrays within a JSON object? (PHP)

我正在使用CSV數據並使用PHP生成JSON,但我想知道是否可以從CSV中獲取某些行以在對象中創建數組,為了清楚起見,請參閱下面的目標:

我有以下示例CSV數據:

songId, title, artists:name[1], artists:main[1], artists:name[2], artists:main[2]
"trk-01", "Track 1", "artist 1", "true", "artist 2", "false"
"trk-02", "Track 2", "artist 3", "true", "artist 4", "false"

(可以格式化以適應解決方案)

以下PHP用於從上面的CSV創建JSON:

if (($handle = fopen('example.csv', 'r')) === false) {
    die('Error opening file');
}
$headers = fgetcsv($handle, 1024, ',');
$complete = array();
while ($row = fgetcsv($handle, 1024, ',')) {
    $complete[] = array_combine($headers, $row);
}
$completeobj = array("tracks" => $complete);
$result = array_merge($completeobj);
fclose($handle);

echo json_encode($result, JSON_PRETTY_PRINT);
$fp = fopen('results.json', 'w');
fwrite($fp, json_encode($result, JSON_PRETTY_PRINT));
fclose($fp);

這樣生成的JSON看起來像:

{
    "tracks": [
        {
            "songId": "trk-01",
            "title": "Track 1",
            "artists:name[1]": "artist 1",
            "artists:main[1]": "true",
            "artists:name[2]": "artist 2",
            "artists:main[2]": "false"
        },
        {
            "songId": "trk-02",
            "title": "Track 2",
            "artists:name[1]": "artist 3",
            "artists:main[1]": "true",
            "artists:name[2]": "artist 4",
            "artists:main[2]": "false"
        }
    ]
}

但我的目標是將這些“藝術家”行放在CSV中並將它們的值放入對象藝術家的數組中,請參閱下面所需的json:

{
    "tracks": [
        {
            "songId": "trk-01",
            "title": "track 1",
            "artists":
            [
                {
                   "name": "Artist 1",
                   "main": true              
                },
                {
                   "name": "Artist 2",
                   "main": false              
                }
            ]
        },
        {
            "songId": "trk-02",
            "title": "track 2",
            "artists":
            [
                {
                   "name": "Artist 3",
                   "main": true              
                },
                {
                   "name": "Artist 4",
                   "main": false              
                }
            ]
        }
    ]
}

如果有人可以提出一個實現這個目標的方法,或者給我一個例子,可以幫助我弄清楚那將是王牌!

在json_encode之前嘗試這個

$new_result = array();
foreach($result['tracks'] as $trackdata){
    $id = $trackdata['songId'];
    $title = $trackdata['title'];
    $name1 = $trackdata['artists:name[1]'];
    $name2 = $trackdata['artists:name[2]'];
    $main1 = $trackdata['artists:main[1]'];
    $main2 = $trackdata['artists:main[2]'];

    $new_result['tracks'][]=array(
        'songID'    => $id,
        'title'     => $title,
        'artists'   => array( 
            0 => array(
                'name' => $name1,
                'main' => $main1,
                ),
            1 => array(
                'name' => $name2,
                'main' => $main2,
            ),
        ),
    );
}

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM