在PHP中解析JSON主要用到j(luò)son_encode和json_decode兩個PHP
創(chuàng)新互聯(lián)專注于鳳泉網(wǎng)站建設(shè)服務(wù)及定制,我們擁有豐富的企業(yè)做網(wǎng)站經(jīng)驗。 熱誠為您提供鳳泉營銷型網(wǎng)站建設(shè),鳳泉網(wǎng)站制作、鳳泉網(wǎng)頁設(shè)計、鳳泉網(wǎng)站官網(wǎng)定制、小程序定制開發(fā)服務(wù),打造鳳泉網(wǎng)絡(luò)公司原創(chuàng)品牌,更為您提供鳳泉網(wǎng)站排名全網(wǎng)營銷落地服務(wù)。
JSON函數(shù),比PHP解析XML方便很多,下面詳細(xì)介紹下PHP
JSON的使用。
JSON基礎(chǔ)介紹
JSON(JavaScript
Object
Notation)
是一種輕量級的數(shù)據(jù)交換格式。
JSON主要有兩種結(jié)構(gòu):
“名稱/值”對的集合,在PHP中可以理解為關(guān)聯(lián)數(shù)組
(associative
array)。
值的有序列表(An
ordered
list
of
values)。在PHP中可以理解為普通數(shù)組(array)。
對象是一個無序的“‘名稱/值'對”集合。一個對象以“{”(左括號)開始,“}”(右括號)結(jié)束。每個“名稱”后跟一個“:”(冒號);“‘名稱/值'
對”之間使用“,”(逗號)分隔。
數(shù)組是值(value)的有序集合。一個數(shù)組以“[”(左中括號)開始,“]”(右中括號)結(jié)束。值之間使用“,”(逗號)分隔。值(value)可以是雙引號括起來的字符串(string)、數(shù)值(number)、true、false、
null、對象(object)或者數(shù)組(array)。這些結(jié)構(gòu)可以嵌套。
我目前對JSON的理解更偏向于數(shù)組,類似于PHP中的關(guān)聯(lián)數(shù)組,你可以將PHP數(shù)組轉(zhuǎn)換為JSON格式。
更多JSON的介紹請參考JSON官網(wǎng)和IBM關(guān)于JSON的介紹
PHP
JSON解析實例
PHP5.2開始已經(jīng)將JSON作為PHP擴(kuò)展的一部分,所以并不需要另外安裝JSON。另外為了保證下面的PHP
JSON實例不出現(xiàn)中文亂碼,請保證你的編碼格式為UTF8。
JSON是Javascript的一部分,首先我們看下Javascript中如何定義JSON
復(fù)制代碼
代碼如下:
var
json_obj
=
{'WebName':'PHP網(wǎng)站開發(fā)教程網(wǎng)'};
alert(json_obj.WebName);
var
json_arr
=[{'WebName':'PHP網(wǎng)站開發(fā)教程網(wǎng)','WebSite':''},{'ArtTitle':'PHP
JSON實例講解'}]
alert(json_arr[1].ArtTitle);
var
php_json
=
[['PHP網(wǎng)站開發(fā)教程網(wǎng)',''],['文章標(biāo)題','PHP
JSON實例講解']];
alert(php_json[1][0]);
在這段JSON實例代碼中我構(gòu)建了所有的JSON形式,
第1行,定義了JSON以對象形式存在
第4行,定義了JSON以數(shù)組形式存在,嵌套了JSON對象,所以有點類似于PHP的關(guān)聯(lián)數(shù)組,其實仍然是對象。
第7行,定了JSON以普通數(shù)組形式存在。
注意:由于Javascript是區(qū)分大小寫的,所以訪問JSON關(guān)聯(lián)數(shù)組對象時注意key的大小寫問題。
PHP與JSON格式數(shù)據(jù)交互時,第一步需要將PHP數(shù)組轉(zhuǎn)換為JSON格式的數(shù)據(jù),可使用PHP5自帶的json_encode函數(shù),當(dāng)PHP解析傳遞過來的JSON格式數(shù)據(jù)時需要使用json_decode函數(shù)進(jìn)行解析轉(zhuǎn)換為PHP數(shù)組,PHP轉(zhuǎn)換并解析JSON數(shù)據(jù)的實例代碼如下
復(fù)制代碼
代碼如下:
?php
$json_arr
=
array('WebName'='PHP網(wǎng)站開發(fā)教程網(wǎng)','WebSite'='');
$php_json
=
json_encode($json_arr);
echo
$php_json;
$php_json
=
json_decode($php_json);
print_r($php_json);
?
說明:這里通過PHP定義了關(guān)聯(lián)數(shù)組,然后通過json_encode轉(zhuǎn)換為JSON格式的數(shù)據(jù),通過echo語句可以看到轉(zhuǎn)換后的JSON對象,通過PHP
JSON解析函數(shù)json_decode可以將JSON格式的數(shù)據(jù)解析為PHP的關(guān)聯(lián)數(shù)組。如果編碼不正確,JSON中文會出現(xiàn)亂碼。如果你使用Editplus調(diào)試PHP,請注意保存文件時編碼將ANSI改為UTF8。
最后我們來看下完整的PHP
JSON交互實例
復(fù)制代碼
代碼如下:
?php
$json_arr
=
array('WebName'='PHP網(wǎng)站開發(fā)教程網(wǎng)','WebSite'='');
$php_json
=
json_encode($json_arr);
?
script
type="text/javascript"
var
php_json
=
?=$php_json?;
/script
script
type="text/javascript"
function
php_json_dis(php_json)
{
alert(php_json.WebName);
alert(php_json.WebSite);
}
php_json_dis(php_json);
/script
至此,PHP通過json_encode和json_decode函數(shù)對JSON格式數(shù)據(jù)進(jìn)行轉(zhuǎn)換和解析的實例就介紹完了。
1:
[id] = 408
[type] = china
[reality] = 120.00
[days] = 2016-06-20
2:
[id] = 408
[totalsave] = 200.00
[days] = 2016-06-20
3:
[id] = 408
[totalsave] = 3800.00
[days] = 2016-06-20
4:
[id] = 408
[totalwithdraw] = 92.00
[should] = 0.7176
[days] = 2016-06-20
5:
[id] = 408
[totalwithdraw] = 3908.00
[should] = 14.8504
[days] = 2016-06-20
結(jié)論
[id] = 408
[totalwithdraw] = 82.00
[should] = 0.6396
[days] = 2016-06-20
[totalsave] = 3800.00
[type] = 中文
[reality] = 0.00
看不出有神馬邏輯關(guān)系。。
post的數(shù)據(jù)也可以是一個json,
php可以用json_encode()把數(shù)組轉(zhuǎn)換成json;
例:
$arr = array('a' = 1, 'b' = 2, 'c' = 3, 'd' = 4, 'e' = 5);
echo json_encode($arr);
{"a":1,"b":2,"c":3,"d":4,"e":5}
這篇文章主要介紹了PHP連接操作access數(shù)據(jù)庫實例,本文直接給出實現(xiàn)代碼,需要的朋友可以參考下
因為之前做的PingSwitch要做一個WEB展示的前端,因為一開始用了Delphi和access的結(jié)構(gòu),而Delphi與MySQL的連接又相對麻煩,最后只能選擇用PHP+Access的組合,比較奇怪,但是也合理·····
在PHP中連接access數(shù)據(jù)庫的話我們必須ADO來連接,這跟ASP中連接數(shù)據(jù)庫非常的類似。下邊給出了一段DEMO供大家參考。
?PHP
/*
創(chuàng)建ADO連接
*/
$conn
=
@new
COM("ADODB.Connection")
or
die
("ADO
Connection
faild.");
$connstr
=
"DRIVER={Microsoft
Access
Driver
(*.mdb)};
DBQ="
.
realpath("DATUM/cnbt.mdb");
$conn-Open($connstr);
/*
創(chuàng)建記錄集查詢
*/
$rs
=
@new
COM("ADODB.RecordSet");
$rs-Open("select
*
from
dbo_dirs",$conn,1,3);
/*
循環(huán)讀取數(shù)據(jù)
*/
while(!$rs-eof){
echo
"$rs-Fields["title"]-Value;
echo
"br/";
$rs-Movenext();
//將記錄集指針下移
}
$rs-close();
?
這樣運(yùn)行就沒問題了····
以上所述就是本文的全部內(nèi)容了,希望大家能夠喜歡。
隊列這種數(shù)據(jù)結(jié)構(gòu)更簡單,就像我們生活中排隊一樣,它的特性是先進(jìn)先出(FIFO)。
PHP
SPL中SplQueue類就是實現(xiàn)隊列操作,和棧一樣,它也可以繼承雙鏈表(SplDoublyLinkedList)輕松實現(xiàn)。
SplQueue類摘要如下:
SplQueue簡單使用如下:
復(fù)制代碼
代碼如下:
$queue
=
new
SplQueue();
/**
*
可見隊列和雙鏈表的區(qū)別就是IteratorMode改變了而已,棧的IteratorMode只能為:
*
(1)SplDoublyLinkedList::IT_MODE_FIFO
|
SplDoublyLinkedList::IT_MODE_KEEP
(默認(rèn)值,迭代后數(shù)據(jù)保存)
*
(2)SplDoublyLinkedList::IT_MODE_FIFO
|
SplDoublyLinkedList::IT_MODE_DELETE
(迭代后數(shù)據(jù)刪除)
*/
$queue-setIteratorMode(SplDoublyLinkedList::IT_MODE_FIFO
|
SplDoublyLinkedList::IT_MODE_DELETE);
//SplQueue::enqueue()其實就是
SplDoublyLinkedList::push()
$queue-enqueue('a');
$queue-enqueue('b');
$queue-enqueue('c');
//SplQueue::dequeue()其實就是
SplDoublyLinkedList::shift()
print_r($queue-dequeue());
foreach($queue
as
$item)
{
echo
$item
.
PHP_EOL;
}
print_r($queue);
而優(yōu)先隊列SplPriorityQueue是基于堆(后文介紹)實現(xiàn)的。
SplPriorityQueue的類摘要如下:
SplPriorityQueue簡單使用:
$pq
=
new
SplPriorityQueue();
$pq-insert('a',
10);
$pq-insert('b',
1);
$pq-insert('c',
8);
echo
$pq-count()
.PHP_EOL;
//3
echo
$pq-current()
.
PHP_EOL;
//a
/**
*
設(shè)置元素出隊模式
*
SplPriorityQueue::EXTR_DATA
僅提取值
*
SplPriorityQueue::EXTR_PRIORITY
僅提取優(yōu)先級
*
SplPriorityQueue::EXTR_BOTH
提取數(shù)組包含值和優(yōu)先級
*/
$pq-setExtractFlags(SplPriorityQueue::EXTR_DATA);
while($pq-valid())
{
print_r($pq-current());
//a
c
b
$pq-next();
}
本文名稱:php數(shù)據(jù)組合實例,php數(shù)據(jù)組合實例怎么做
鏈接分享:http://www.chinadenli.net/article14/heihge.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供面包屑導(dǎo)航、網(wǎng)站排名、Google、企業(yè)建站、微信小程序、網(wǎng)頁設(shè)計公司
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)