php读取csv文件返回json,PHP将CSV转换为特定的JSON格式

我有一个CSV文件,如下所示:

Name, Id, Address, Place,

John, 12, "12 mark street", "New York",

Jane, 11, "11 bark street", "New York"...

我有大约500个coloumns.我想将其转换为JSON,但我希望输出看起来像:

{

"name": [

"John",

"Jane"

],

"Id": [

12,

11

],

"Address": [

"12 mark street",

"12 bark street"

],

"Place": [

"New York",

"New York"

]

}

使用PHP,我如何迭代CSV文件,以便我可以使第一行中的每一列成为一个数组,该数组在所有其他行的同一列中保存值?

解决方法:

这将是一个通用方法,对任何命名列的amoutn都有效.

如果它们是静态的,则直接解决它们会更短

$result = array();

if (($handle = fopen("file.csv", "r")) !== FALSE) {

$column_headers = fgetcsv($handle); // read the row.

foreach($column_headers as $header) {

$result[$header] = array();

}

while (($data = fgetcsv($handle)) !== FALSE) {

$i = 0;

foreach($result as &$column) {

$column[] = $data[$i++];

}

}

fclose($handle);

}

$json = json_encode($result);

echo $json;

标签:php,json,csv,parsing

来源: https://codeday.me/bug/20191007/1864065.html

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值