Warning: file_get_contents(/data/phpspider/zhask/data//catemap/5/objective-c/27.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Php 将fgetcsv响应转换为特定json_Php_Arrays_Json_Fgetcsv - Fatal编程技术网

Php 将fgetcsv响应转换为特定json

Php 将fgetcsv响应转换为特定json,php,arrays,json,fgetcsv,Php,Arrays,Json,Fgetcsv,我有一个带有标题的.CSV文件: Description, BusinessSurname, IsCustomer, IsSupplier, AddressType, Business Address, IsInternational. 第一行: Contact1, Contact1, True, True, Business, 123 Fake St, False 剩下的行并不重要,只是更像是示例。我这里有几行数据 我需要将其转换为以下格式: { Description:'Desc_47

我有一个带有标题的.CSV文件:

Description, BusinessSurname, IsCustomer, IsSupplier, AddressType, Business 
Address, IsInternational.
第一行:

Contact1, Contact1, True, True, Business, 123 Fake St, False
剩下的行并不重要,只是更像是示例。我这里有几行数据

我需要将其转换为以下格式:

{
Description:'Desc_47AE3208-87F5-4BBA-BE40-AA4130AB4768',
SurnameBusinessName:'Name_Business',
IsCustomer:true,
IsSupplier:true,
Addresses:
[
{AddressType:'Business',Line1:'addr1_bus',IsInternational:false},
{AddressType:'Postal',Line1:'addr1_pos',IsInternational:true}
]
}
我尝试了几种不同的方法,但没有一种方法专门为我提供这样的地址嵌套的json。我可以不填第二个地址和邮政地址

如果我使用此代码:

        $filename = 'contacts1.csv';
        $handle = fopen($filename, 'r');
        $count = 0;
        while (($data = fgetcsv($handle)) !== FALSE) {
            $count++;
            if ($count == 1){
                continue;
            }
        $json = json_encode($data, true);
        echo $json;
        };
我举个例子:

["Contact1","Contact1","TRUE","TRUE","Business","123 High Street Sydney NSW 2000","FALSE"]
["Contact2","Contact2","TRUE","TRUE","Business","124 High Street Sydney NSW 2000","FALSE"]
["Contact3","Contact3","TRUE","TRUE","Business","125 High Street Sydney NSW 2000","FALSE"]
有没有办法获取我需要的json,如果我不能自动获取所需的json,有没有办法提取每行的值,分配给变量,并使用for循环、while循环等手动为每行创建所需的json?例如:

{
Description: $description,
SurnameBusinessName: $BusinessSurname,
etc...
}

我找到了这个问题的答案,但是我放弃了这个API端点,选择了一个更简单的没有嵌套的端点。由于json格式的严格性,该API将接受我基本上将csv中的每个值分配给一个变量,并手动创建所需的json。尽管下面的代码是针对Accounts端点的,但我可以对任何端点使用完全相同的方法,因为我需要手动创建json。我认为这是它工作的唯一方式,因为有些字段是像AccountName这样的字符串,有些是像accounttype这样的整数

$file = 'acc.csv';
    $mode = 'r';
    $handle = fopen($file, $mode);
    while(($csv = fgetcsv($handle)) !==FALSE){
        foreach($csv as $row => $value){
            $data = $row.$value;
            switch ($row){
                case '0':
                    $accounttype = $value;
                    break;
                case '1':
                    $accountname = $value;
                    break;
                case '2':
                    $hint = $value;
                    break;
                case '3':
                    $status = $value;
                    break;
                case '4':
                    $sortorder = $value;
                    break;
                case '5':
                    $accountcode = $value;
                    break;
                case '6':
                    $parentaccountcatid = $value;

                    $json = "
                    {
      AccountType:" . $accounttype . ",
      AccountName:'" . $accountname . "',
      Hint:'" . $hint . "',
      Status:" . $status . ",
      SortOrder:" . $sortorder . ",
      AccountCode:'" . $accountcode . "',
      ParentAccountingCategoryID:'" . $parentaccountcatid . "'
     }"; 
    //echo $json; 

连同csv标题-显示csv行我已经显示了csv行的示例。谢谢通过查看我得到的输出,您已经可以看到csv行中的内容。基本上是一样的。这里已经回答了: