J'ai parcouru de nombreux articles sur la recherche de valeur à partir d'un tableau complexe, mais tous ne vont qu'au deuxième niveau. Quelqu'un peut-il s'il vous plaît me fournir un code pour trouver de manière récursive la valeur par exemple state dans address_line_2 si elle existe ou non?

J'ai le JSON suivant

{
  "company": {
    "id": "123456",
    "name": "Test Company LLC.",
    "FEIN": "22-2222222",
    "address": {
      "address_line_1": {
        "street": "1 Street St, Suite 12",
        "city": "San Francisco",
        "postalCode": "123456"
      },
      "address_line_2": {
        "state": "CA",
        "country": "USA"
      }
    },
    "phone": "1-800-XXX-XXXX",
    "fax": "1-800-XXX-XXXX",
    "email": "admin@abc.com",
    "URL": "www.abc.com"
  },
  "producer": {
    "id": "LLXXXX",
    "name": "Test Name",
    "phone": "555-555-5555",
    "mobile": "555-555-5555",
    "fax": "555-555-5555",
    "email": "test@abc.com",
    "producerSubCode": "111",
    "NIPRId": "123456",
    "stateProducerId": "12344"
  }
}

~ Harshit

-1
iamharshit 23 mai 2018 à 10:38

3 réponses

Meilleure réponse
<?php

$json_string = '{"company":{"id":"123456","name":"Test Company LLC.","FEIN":"22-2222222","address":{"address_line_1":{"street":"1 Street St, Suite 12","city":"San Francisco","postalCode":"123456"},"address_line_2":{"state":"CA","country":"USA"}},"phone":"1-800-XXX-XXXX","fax":"1-800-XXX-XXXX","email":"admin@abc.com","URL":"www.abc.com"},"producer":{"id":"LLXXXX","name":"Test Name","phone":"555-555-5555","mobile":"555-555-5555","fax":"555-555-5555","email":"test@abc.com","producerSubCode":"111","NIPRId":"123456","stateProducerId":"12344"}}';

$json_array = json_decode($json_string,true);

function getData($json_array,$search_value){
    foreach($json_array as $each_key => $each_value){
        if($each_key === $search_value) return true;
        if(is_array($each_value)){
            $return_value = getData($each_value,$search_value);
            if($return_value !== false) return $return_value === true ? $return_value : $each_key."=>".$return_value;
        }else if($each_value === $search_value){
            return $each_key;
        }
    }

    return false;
}

echo "<pre>";
var_dump(getData($json_array,'San Francisco'));
var_dump(getData($json_array,'producerSubCode'));
var_dump(getData($json_array,'abc123'));

SORTIE

string(38) "company=>address=>address_line_1=>city"
bool(true)
bool(false)

HYPOTHÈSES

Chaque clé et valeur est unique dans le tableau.

DÉFINITION DES FONCTIONS

La fonction getData() recherche une chaîne donnée dans le tableau.

  • Si la chaîne se trouve être un key, elle renvoie un booléen true
  • Si la chaîne se trouve être un value dans le tableau, elle renvoie un key.
  • Si la chaîne ne correspond ni à key ni à value, elle renvoie la valeur booléenne false.
1
vivek_23 23 mai 2018 à 12:09

Au lieu d'en faire un tableau. Qu'en est-il de l'analyse en tant que chaîne avec regex?

$find = "San Francisco";
$re = '/(' . $find . ')\":\s\"(.*?)\"|\"(\w+)\":\s\"(' . $find . ')/m';
$str = '{ "company": { "id": "123456", "name": "Test Company LLC.", "FEIN": "22-2222222", "address": { "address_line_1": { "street": "1 Street St, Suite 12", "city": "San Francisco", "postalCode": "123456" }, "address_line_2": { "state": "CA", "country": "USA" } }, "phone": "1-800-XXX-XXXX", "fax": "1-800-XXX-XXXX", "email": "admin@abc.com", "URL": "www.abc.com" }, "producer": { "id": "LLXXXX", "name": "Test Name", "phone": "555-555-5555", "mobile": "555-555-5555", "fax": "555-555-5555", "email": "test@abc.com", "producerSubCode": "111", "NIPRId": "123456", "stateProducerId": "12344" } }';

preg_match_all($re, $str, $matches);

$result["key-match"] = array_slice(array_column($matches, 0),1,2);
$result["value-match"] = array_slice(array_column($matches, 0),3,2);
var_dump($result);

$find peut être une clé ou une valeur.
Le tableau de résultats contiendra deux sous-tableaux avec soit s'il s'agit d'une correspondance de clé, soit d'une correspondance de valeur.

https://3v4l.org/05dm3

0
Andreas 23 mai 2018 à 08:59

Vous pouvez utiliser array_column pour obtenir la valeur d'une clé donnée

$ array = json_decode ($ json, vrai);

$ names = array_column ($ array, 'nom');

0
MGrahl 23 mai 2018 à 08:05