Como criar uma matriz para JSON usando PHP?

126

No código PHP, quero criar uma matriz json:

[
  {"region":"valore","price":"valore2"},
  {"region":"valore","price":"valore2"},
  {"region":"valore","price":"valore2"}
]

Como posso fazer isso?

Mimmo
fonte
1
possível duplicata de Como gerar arquivo .json com PHP?
precisa saber é o seguinte

Respostas:

154

Squeezy de limão fácil e fácil: http://www.php.net/manual/en/function.json-encode.php

<?php
$arr = array('a' => 1, 'b' => 2, 'c' => 3, 'd' => 4, 'e' => 5);

echo json_encode($arr);
?>

Há uma postagem andyrusterholz at g-m-a-i-l dot c-o-mna página mencionada acima que também pode lidar com matrizes aninhadas complexas (se é isso que você gosta).

David Titarenco
fonte
2
Dang, mano, você foi instantâneo nessa resposta =). Eu estava animado com a pergunta fácil =)
Calvin Froedge
2
Eu tenho esse código while ($ row = mysql_fetch_assoc ($ query_insert)) {$ control = array ('regione' => $ row ["regione"], 'totale' => $ row ["prezzi"]); } print (json_encode (% de controle)); mas retun { "regione": "Puglia", "totale": "5,15"} não [{..}, {..}]
Mimmo
2
Adicione 1 para a referência de limão. :-)
ban-geoengineering
Eu fiz isso, mas a resposta que recebo usando a função var_dumb é a seguinte. Como posso me livrar da string (59)? string (59) "[{" result ":" success "}, {" message ":" Dados atualizados! "}]"
James Smith
115

Use o nativo do PHP json_encode, assim:

<?php
$arr = array(
    array(
        "region" => "valore",
        "price" => "valore2"
    ),
    array(
        "region" => "valore",
        "price" => "valore2"
    ),
    array(
        "region" => "valore",
        "price" => "valore2"
    )
);

echo json_encode($arr);
?>

Atualização : para responder à sua pergunta no comentário. Você faz assim:

$named_array = array(
    "nome_array" => array(
        array(
            "foo" => "bar"
        ),
        array(
            "foo" => "baz"
        )
    )
);
echo json_encode($named_array);
Shef
fonte
2
Com licença, mas se eu quiser {"nome_array": [{"foo": "bar"}, {"foo": "baz"}]} ??
Mimmo
41

Simples: basta criar uma matriz PHP (aninhada) e ligar json_encodepara ela. Matrizes numéricas são convertidas em listas JSON ( []), matrizes associativas e objetos PHP convertidas em objetos ( {}). Exemplo:

$a = array(
        array('foo' => 'bar'),
        array('foo' => 'baz'));
$json = json_encode($a);

Da-te:

[{"foo":"bar"},{"foo":"baz"}]
tdammers
fonte
1
Com licença, mas se eu quiser {"nome_array": [{"foo": "bar"}, {"foo": "baz"}]} ??
18711 Mimmo
2
Leia meu post novamente. Se você deseja que algo se traduza em um objeto JSON, torne-o um array associativo em PHP (onde as chaves são cadeias). Se você deseja que ele se traduza em uma lista JSON, torne-o uma matriz simples (com chaves inteiras implícitas). O valor de cada elemento da matriz pode, por sua vez, ser uma matriz, que é o que você deseja.
tdammers
Graças isso respondeu minha pergunta também.
precisa saber é o seguinte
Eu fiz isso, mas a resposta que recebo usando a função var_dumb é a seguinte. Como posso me livrar da string (59)? string (59) "[{" result ":" success "}, {" message ":" Dados atualizados! "}]"
James Smith
13

A melhor maneira de você criar sempre o json no php é primeiro converter valores no array ASSOCIATIVE.

Depois disso, basta codificar usando json_encode($associativeArray). Eu acho que é a melhor maneira de criar json em php, porque sempre que estamos buscando resultado da consulta sql em php na maioria das vezes obtemos valores usando a fetch_assocfunção, que também retorna uma matriz associativa.

$associativeArray = array();
$associativeArray ['FirstValue'] = 'FirstValue';

... etc.

Depois disso.

json_encode($associativeArray);
Parveen Verma
fonte
3

também para array, você pode usar anotações curtas:

$arr = [
    [
        "region" => "valore",
        "price" => "valore2"
    ],
    [
        "region" => "valore",
        "price" => "valore2"
    ],
    [
        "region" => "valore",
        "price" => "valore2"
    ]
];

echo json_encode($arr);
dwaskowski
fonte
3

É assim que posso fazer com a ajuda da solução dada por @tdammers abaixo. A linha a seguir será colocada dentro do loop foreach.

$array[] = array('power' => trim("Some value"), 'time' => "time here" );

E então codifique a matriz com a função json encode

json_encode(array('newvalue'=> $array), 200)
iZeeshan
fonte
1

Digitar esta única linha forneceria uma matriz json,

echo json_encode($array);

Normalmente você usa json_encodepara ler dados de um aplicativo iOS ou Android. portanto, certifique-se de não repetir nada além da matriz json precisa.

theModerator713
fonte
1
$json_data = '{ "Languages:" : [ "English", "Spanish" ] }';
$lang_data = json_decode($json_data);
var_dump($lang_data);
Mateus
fonte
Como você adicionaria dinamicamente um novo idioma ao nó de idiomas no PHP? Obrigado.
0
<?php 

    $username=urldecode($_POST['log_user']);

    $user="select * from tbl_registration where member_id= '".$username."' ";
    $rsuser = $obj->select($user);
    if(count($rsuser)>0)
    {
        //   (Status if 2 then its expire)    (1= use) ( 0 = not use)

        $cheknew="select name,ldate,offer_photo  from tbl_offer where status=1 ";
        $rscheknew = $obj->selectjson($cheknew);

        if(count($rscheknew)>0)
        {

             $nik=json_encode($rscheknew);
            echo "{\"status\" : \"200\" ,\"responce\" : \"201\", \"message\" : \"Get Record\",\"feed\":".str_replace("<p>","",$nik). "}";
        }
        else
        {
            $row2="No Record Found";
            $nik1=json_encode($row2);
            echo "{\"status\" : \"202\",  \"responce\" : \"604\",\"message\" : \"No Record Found \",\"feed\":".str_replace("<p>","",$nik1). "}";
        }
    }
    else
    {
        $row2="Invlid User";
        $nik1=json_encode($row2);
        echo "{\"status\" : \"404\", \"responce\" : \"602\",\"message\" : \"Invlid User \",\"feed\":".str_replace("<p>","",$nik1). "}";
    }

 ?>
iamasp
fonte
0

Criei uma classe jsonOBJ crua e simples para usar no meu código. O PHP não inclui funções json como JavaScript / Node. Você precisa iterar de maneira diferente, mas pode ser útil.

<?php

// define a JSON Object class
class jsonOBJ {
    private $_arr;
    private $_arrName;

    function __construct($arrName){
        $this->_arrName = $arrName;
        $this->_arr[$this->_arrName] = array();

    }

    function toArray(){return $this->_arr;}
    function toString(){return json_encode($this->_arr);}

    function push($newObjectElement){
        $this->_arr[$this->_arrName][] = $newObjectElement; // array[$key]=$val;
    }

    function add($key,$val){
        $this->_arr[$this->_arrName][] = array($key=>$val);
    }
}

// create an instance of the object
$jsonObj = new jsonOBJ("locations");

// add items using one of two methods
$jsonObj->push(json_decode("{\"location\":\"TestLoc1\"}",true)); // from a JSON String
$jsonObj->push(json_decode("{\"location\":\"TestLoc2\"}",true));

$jsonObj->add("location","TestLoc3"); // from key:val pairs

echo "<pre>" . print_r($jsonObj->toArray(),1) . "</pre>";
echo "<br />" . $jsonObj->toString();
?>

Saída:

Array
(
    [locations] => Array
        (
            [0] => Array
                (
                    [location] => TestLoc1
                )

            [1] => Array
                (
                    [location] => TestLoc2
                )

            [2] => Array
                (
                    [location] => TestLoc3
                )

        )

)


{"locations":[{"location":"TestLoc1"},{"location":"TestLoc2"},{"location":"TestLoc3"}]}

Para iterar, converta para um objeto normal:

$myObj = $jsonObj->toArray();

Então:

foreach($myObj["locations"] as $locationObj){
    echo $locationObj["location"] ."<br />";
}

Saídas:

TestLoc1
TestLoc2
TestLoc3

Acesso direto:

$location = $myObj["locations"][0]["location"];
$location = $myObj["locations"][1]["location"];

Um exemplo prático:

// return a JSON Object (jsonOBJ) from the rows
    function ParseRowsAsJSONObject($arrName, $rowRS){
        $jsonArr = new jsonOBJ($arrName); // name of the json array

        $rows = mysqli_num_rows($rowRS);
        if($rows > 0){
            while($rows > 0){
                $rd = mysqli_fetch_assoc($rowRS);
                $jsonArr->push($rd);
                $rows--;
            }
            mysqli_free_result($rowRS);
        }
        return $jsonArr->toArray();
    }
Jeffrey Meyer
fonte