php数据生成json php数据生成图形

php转换成json数据格式json和php数组 格式php数据生成json的互相转换php数据生成json,参考如下php数据生成json:$php_json = json_encode($json_arr);//把php数组格式转换成 json 格式php数据生成json的数据echo $php_json;$php_json = json_decode($php_json);//再把json格式的数据转换成php数组print_r($php_json);json数组$json = '[{"id":"22","name":"33","descn":"44"}]';//json格式的数组转换成 php的数组$arr = (Array)json_decode($json);echo $arr[0]-id;//用对象的方式访问
像这样的问题很常见,没必要在到处问,php数据生成json你多在后盾找找就不必这么麻烦了
PHP查询数据库表 , 如何生成二维JSONmysql查询某个数据库下所有表名的sql语句:
SELECT TABLE_NAME FROM INFORMATION_SCHEMA.TABLES WHERE TABLE_SCHEMA = '数据库名称'
具体生成示例如下:
?php
//连接数据库
$con = mysql_connect("localhost","root","");
if (!$con)
{
die('Could not connect: ' . mysql_error());
}
//选择要操作的数据库
mysql_select_db("activity");
//sql语句
$sql="SELECT TABLE_NAME FROM INFORMATION_SCHEMA.TABLES WHERE TABLE_SCHEMA = 'activity'";
//执行sql
$result=mysql_query($sql);
$arr=array();
$i=0;
while($row=mysql_fetch_row($result))
{
$arr[$i] = $row[0];
$i++;
}
//将结果转换为json格式
$json=json_encode($arr);
//输出结果
print_r($json);
//关闭mysql数据库连接
mysql_close($con);
?
生成结果:
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 {
constERROR_CODE = '404';
public$public_ex ='this is public';
private$private_ex ='this is private!';

推荐阅读