如何用php轉json數據,php怎麼輸出json

本文目錄一覽:

php怎麼把資料庫數據轉化成json

//演示用過程化風格,如需要,自行翻譯成面向對象風格

//讓瀏覽器識別json

header(‘Content-type: application/json’);

//1、連接資料庫

$conn = mysqli_connect(“localhost”,”my_user”,”my_password”,”my_db”);

//2、查詢

$query= mysqli_query($conn,”select * form table where 1 limit 10″);

$res = [];

//3、將查詢結果賦值給變數res

while($res = mysqli_fetch_assoc($query)){

    $res[] = $res;

}

//4、輸出json

echo json_encode($res);

用php如何將數據(文本和圖片)轉換成json格式

前台:

form action=”跳轉頁面” method=”post” enctype=”multipart/form-data”

input type=”file” name=”fname” /

input type=”submit” value=”Submit” /

/form

input[type=file] 表示:需要上傳的文本或者圖片

後台:

echo json_encode($_POST); // 輸出json 字元串

輸出的內容是上傳到伺服器的文件路徑等相關信息

php轉換成json數據格式

其實就是把這3個結果並成一個數組,再轉就是了例如,$res1=mysql_query($sql1);$res2=mysql_query($sql2);$res3=mysql_query($sql3);定義一個新的數組$a=array();將3個結果壓入這個新的數組array_push($a,$res1);array_push($a,$res2);array_push($a,$res3);最後轉義輸出echojson_encode($a);LZ遇到問題不要氣餒呀

PHP是怎麼返回json格式的數據

1、php 輸出JSON格式,使用json_encode函數即可

2、示例:

?php

header(‘Content-type: text/json’);

$fruits = array (

“fruits” = array(“a” = “orange”, “b” = “banana”, “c” = “apple”),

“numbers” = array(1, 2, 3, 4, 5, 6),

“holes” = array(“first”, 5 = “second”, “third”)

);

echo json_encode($fruits);

?

示例得到結果:

{“fruits”:{“a”:”orange

php怎麼將數組數組轉化為json格式的數據

一、json_encode()

[php] view plain copy

?php

$arr =array (‘a’=1,’b’=2,’c’=3,’d’=4,’e’=5);

echo json_encode($arr);

?

輸出

[php] view plain copy

{“a”:1,”b”:2,”c”:3,”d”:4,”e”:5}

再看一個對象轉換的例子:

[php] view plain copy

$obj-body           = ‘another post’;

$obj-id             = 21;

$obj-approved       = true;

$obj-favorite_count = 1;

$obj-status         = NULL;

echo json_encode($obj);

輸出

[php] view plain copy

{

“body”:”another post”,

“id”:21,

“approved”:true,

“favorite_count”:1,

“status”:null

}

 由於json只接受utf-8編碼的字元,所以json_encode()的參數必須是utf-8編碼,否則會得到空字元或者null。當中文使用GB2312編碼,或者外文使用ISO-8859-1編碼的時候,這一點要特別注意。

二、索引數組和關聯數組

PHP支持兩種數組,一種是只保存”值”(value)的索引數組(indexed array),另一種是保存”名值對”(name/value)的關聯數組(associative array)。

由於javascript不支持關聯數組,所以json_encode()只將索引數組(indexed array)轉為數組格式,而將關聯數組(associative array)轉為對象格式。

比如,現在有一個索引數組

[php] view plain copy

$arr = Array(‘one’,’two’, ‘three’);

echo json_encode($arr);

輸出

[php] view plain copy

[“one”,”two”,”three”]

如果將它改為關聯數組:

[php] view plain copy

$arr = Array(‘1’=’one’,’2’=’two’,’3’=’three’);

echo json_encode($arr);

輸出變為

[php] view plain copy

{“1″:”one”,”2″:”two”,”3″:”three”}

 注意,數據格式從”[]”(數組)變成了”{}”(對象)。

如果你需要將”索引數組”強制轉化成”對象”,可以這樣寫

[php] view plain copy

json_encode( (object)$arr);

或者

[php] view plain copy

json_encode ( $arr, JSON_FORCE_OBJECT );

三、類(class)的轉換

下面是一個PHP的類:

[php] view plain copy

class Foo {

const    ERROR_CODE = ‘404’;

public   $public_ex =’this is public’;

private  $private_ex =’this is private!’;

protected$protected_ex =’this should be protected’;

publicfunction getErrorCode() {

returnself::ERROR_CODE;

}

}

 現在,對這個類的實例進行json轉換:

[php] view plain copy

$foo =new Foo;

$foo_json = json_encode($foo);

echo $foo_json;

 輸出結果是

[php] view plain copy

{“public_ex”:”this is public”}

四、json_decode() 可以看到,除了公開變數(public),其他東西(常量、私有變數、方法等等)都遺失了。

該函數用於將json文本轉換為相應的PHP數據結構。下面是一個例子:

[php] view plain copy

$json ='{“foo”: 12345}’;

$obj = json_decode($json);

print $obj-{‘foo’};// 12345

通常情況下,json_decode()總是返回一個PHP對象,而不是數組。比如:

[php] view plain copy

$json ='{“a”:1,”b”:2,”c”:3,”d”:4,”e”:5}’;

var_dump(json_decode($json));

結果就是生成一個PHP對象:

[php] view plain copy

object(stdClass)#1 (5) {

[“a”] = int(1)

[“b”] = int(2)

[“c”] = int(3)

[“d”] = int(4)

[“e”] = int(5)

}

 如果想要強制生成PHP關聯數組,json_decode()需要加一個參數true:

[php] view plain copy

$json ='{“a”:1,”b”:2,”c”:3,”d”:4,”e”:5}’;

var_dump(json_decode($json,true));

結果就生成了一個關聯數組:

[php] view plain copy

array(5) {

[“a”] = int(1)

[“b”] = int(2)

[“c”] = int(3)

[“d”] = int(4)

[“e”] = int(5)

}

下面三種json寫法都是錯的,你能看出錯在哪裡嗎?五、json_decode()的常見錯誤

[php] view plain copy

$bad_json =”{ ‘bar’: ‘baz’ }”;

$bad_json ='{ bar: “baz” }’;

$bad_json ='{ “bar”: “baz”, }’;

第一個的錯誤是,json的分隔符(delimiter)只允許使用雙引號,不能使用單引號。第二個的錯誤是,json名值對的”名”(冒號左邊的部分),任何情況下都必須使用雙引號。第三個的錯誤是,最後一個值之後不能添加逗號(trailing comma)。 對這三個字元串執行json_decode()都將返回null,並且報錯。

另外,json只能用來表示對象(object)和數組(array),如果對一個字元串或數值使用json_decode(),將會返回null。

[php] view plain copy

var_dump(json_decode(“Hello World”));//null

php轉換成json數據格式是怎麼轉換的?

其實就是把這3個結果並成一個數組,再轉就是了

例如,

$res1=mysql_query($sql1);

$res2=mysql_query($sql2);

$res3=mysql_query($sql3);

定義一個新的數組 $a = array();

將3個結果壓入這個新的數組

array_push($a,$res1);

array_push($a,$res2);

array_push($a,$res3);

最後轉義輸出

echo json_encode($a);

LZ遇到問題不要氣餒呀

原創文章,作者:小藍,如若轉載,請註明出處:https://www.506064.com/zh-tw/n/159310.html

(0)
打賞 微信掃一掃 微信掃一掃 支付寶掃一掃 支付寶掃一掃
小藍的頭像小藍
上一篇 2024-11-19 18:59
下一篇 2024-11-19 18:59

相關推薦

  • PHP和Python哪個好找工作?

    PHP和Python都是非常流行的編程語言,它們被廣泛應用於不同領域的開發中。但是,在考慮擇業方向的時候,很多人都會有一個問題:PHP和Python哪個好找工作?這篇文章將從多個方…

    編程 2025-04-29
  • Python讀取CSV數據畫散點圖

    本文將從以下方面詳細闡述Python讀取CSV文件並畫出散點圖的方法: 一、CSV文件介紹 CSV(Comma-Separated Values)即逗號分隔值,是一種存儲表格數據的…

    編程 2025-04-29
  • 如何用Python寫愛心

    本文將會從多個方面闡述如何用Python語言來畫一個美麗的愛心圖案。 一、準備工作 在開始編寫程序之前,需要先理解一些編程基礎知識。首先是繪圖庫。Python有很多繪圖庫,常見的有…

    編程 2025-04-29
  • Python中讀入csv文件數據的方法用法介紹

    csv是一種常見的數據格式,通常用於存儲小型數據集。Python作為一種廣泛流行的編程語言,內置了許多操作csv文件的庫。本文將從多個方面詳細介紹Python讀入csv文件的方法。…

    編程 2025-04-29
  • 如何用Python統計列表中各數據的方差和標準差

    本文將從多個方面闡述如何使用Python統計列表中各數據的方差和標準差, 並給出詳細的代碼示例。 一、什麼是方差和標準差 方差是衡量數據變異程度的統計指標,它是每個數據值和該數據值…

    編程 2025-04-29
  • Python多線程讀取數據

    本文將詳細介紹多線程讀取數據在Python中的實現方法以及相關知識點。 一、線程和多線程 線程是操作系統調度的最小單位。單線程程序只有一個線程,按照程序從上到下的順序逐行執行。而多…

    編程 2025-04-29
  • Python爬取公交數據

    本文將從以下幾個方面詳細闡述python爬取公交數據的方法: 一、準備工作 1、安裝相關庫 import requests from bs4 import BeautifulSou…

    編程 2025-04-29
  • Python兩張表數據匹配

    本篇文章將詳細闡述如何使用Python將兩張表格中的數據匹配。以下是具體的解決方法。 一、數據匹配的概念 在生活和工作中,我們常常需要對多組數據進行比對和匹配。在數據量較小的情況下…

    編程 2025-04-29
  • Python數據標準差標準化

    本文將為大家詳細講述Python中的數據標準差標準化,以及涉及到的相關知識。 一、什麼是數據標準差標準化 數據標準差標準化是數據處理中的一種方法,通過對數據進行標準差標準化可以將不…

    編程 2025-04-29
  • 如何使用Python讀取CSV數據

    在數據分析、數據挖掘和機器學習等領域,CSV文件是一種非常常見的文件格式。Python作為一種廣泛使用的編程語言,也提供了方便易用的CSV讀取庫。本文將介紹如何使用Python讀取…

    編程 2025-04-29

發表回復

登錄後才能評論