1

我想将 CSV 文件导出到 JSON 文件,需要在推荐字段读取值并写入 JSON 文件。示例:IN row 1,recomnend =2 将读取 id=2 的行并打印到 JSON 文件的值:id,product_id,title。

$json = array();

        $json['id'] = $row['id'];
        $json['product_id'] = $row['product_id'];
        $json['title'] = $row['title'];
        $json['outline'] = $row['outline'];
        $recom[] = $json;  
print json_encode($recom);

http://ns0.upanh.com/b6.s33.d3/3a3ebb93a87c5703f673b399d5613ec2_50639320.untitled.png

4

1 回答 1

1

我不知道有什么不同的方法,但以下方法会起作用。使用这种方法意味着您必须使用列索引,而不是它的名称。如果您知道所需值的列索引,这应该不是问题,但我只是想我会提到:

$fp = fopen('test.csv','r') or die("**! can't open file\n\n");
while($csv_line = fgetcsv($fp,1024)) {
    $id = $csv_line[0];
    $product_id = $csv_line[1];
    $title = $csv_line[2];
    $outline = $csv_line[3];        
}
fclose($fp) or die("**! can't close file\n\n");

现在,因为您将拥有多行,所以我建议您使用以下方法将它们保存到一个 JSON 对象中:

$fp = fopen('test.csv','r') or die("**! can't open file\n\n");
$i = 0;
while($csv_line = fgetcsv($fp,1024)) {
    $i++;
    $json['json_'.$i]['id'] = $csv_line[0];
    $json['json_'.$i]['product_id'] = $csv_line[1];
    $json['json_'.$i]['title'] = $csv_line[2];
    $json['json_'.$i]['outline'] = $csv_line[3];        
}
$json['total_lines'] = $i;
print json_encode($json);
fclose($fp) or die("**! can't close file\n\n");

使用此方法,您可以将每一行保存为子 JSON 对象,从而可以提取总数并通过对象解析以提取行。

于 2012-11-07T04:18:11.817 回答