php - 使用 PHP 将 CSV 转换为 JSON

标签 php json csv

我正在尝试使用 PHP 将 CSV 文件转换为 JSON。

这是我的代码

<?php 

date_default_timezone_set('UTC');
$today = date("n_j"); // Today is 1/23/2015 -> $today = 1_23

$file_name = $today.'.CSV'; // My file name is 1_23.csv
$file_path = 'C:\\Users\\bheng\\Desktop\\qb\\'.$file_name;
$file_handle = fopen($file_path, "r");

$result = array();

if ($file_handle !== FALSE) {

    $column_headers = fgetcsv($file_handle); 
    foreach($column_headers as $header) {
            $result[$header] = array();

    }
    while (($data = fgetcsv($file_handle)) !== FALSE) {
        $i = 0;
        foreach($result as &$column) {
                $column[] = $data[$i++];
        }
    }
    fclose($file_handle);
}

// print_r($result); // I see all data(s) except the header

$json = json_encode($result);
echo $json;

?>

print_r($result); // I see all data(s)

然后我 json_encode($result); 并尝试显示它,但屏幕上根本没有显示任何内容。我看到的只是空白屏幕和 0 错误消息。

我做错了什么吗?有人能帮我吗 ?

Added Result of print_r($result);

Array (
    [Inventory] => Array (
        [0] => bs-0468R(20ug)
        [1] => bs-1338R(1ml)
        [2] => bs-1557G(no bsa)
        [3] => bs-3295R(no BSA)
        [4] => bs-0730R-Cy5"
        [5] => bs-3889R-PE-Cy7"
        [6] => 11033R
        [7] => 1554R-A647
        [8] => 4667
        [9] => ABIN731018
        [10] => Anti-DBNL protein 

        .... more .... 

最佳答案

试试这样:

$file="1_23.csv";
$csv= file_get_contents($file);
$array = array_map("str_getcsv", explode("\n", $csv));
$json = json_encode($array);
print_r($json);

关于php - 使用 PHP 将 CSV 转换为 JSON,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/28118101/

相关文章:

c# - 数组的 MVC JSON 对象未正确设置

php - 将 .po 文件导出为 .csv

c++ - Getline 函数不解析 CSV 文件中的行尾

javascript - Ajax 调用循环,Ajax jQuery

php - 如何在 laravel eloquent 中为左连接表添加别名

php - 如何获取 Woocommerce 变体 ID?

PHP Mysql更新集替换完全匹配

javascript - 将 JSON 数据传递到 div 框中

csv - 如何使用 Beyond Compare 按名称而不是顺序比较匹配列的数据文件

php - 脚本必须在 24 小时内执行 X 次。我如何随机化它?