php获取json的问题
现在我的问题是,我正在使用highChart,其中它的一个属性为series,要使用到外部数据。我准备使用php从数据库中获取数据使用json。
serise属性中的data格式为
[{
name: 'Tokyo',
data: [7.0, 6.9, 9.5, 14.5, 18.2, 21.5, 25.2, 26.5, 23.3, 18.3, 13.9, 9.6]
}, {
name: 'New York',
data: [-0.2, 0.8, 5.7, 11.3, 17.0, 22.0, 24.8, 24.1, 20.1, 14.1, 8.6, 2.5]
}, {
name: 'Berlin',
data: [-0.9, 0.6, 3.5, 8.4, 13.5, 17.0, 18.6, 17.9, 14.3, 9.0, 3.9, 1.0]
}, {
name: 'London',
data: [3.9, 4.2, 5.7, 8.5, 11.9, 15.2, 17.0, 16.6, 14.2, 10.3, 6.6, 4.8]
}]
但是数据库中的获取data时是这样的,一个字段对应一个name,字段下的所有数据对应于data,问题就是如何获取这些数据,因为拼接成这样的json数组的话,发现不太好做。 另外,我使用js直接获取了表单中td的数据,组装成了这种格式的json,直接在series上调用js方法,发现不行。是不是因为要么直接在data域中放数据,要么在name、data等后面放数据,而不是把这个格式的数据放入series中。
凋零的枪花
11 years ago
Answers
<?php
$arr[0]['name'] = 'Tokyo';
$arr[0]['data'] = array( 7.0, 6.9, 9.5, 14.5, 18.2, 21.5, 25.2, 26.5, 23.3, 18.3, 13.9, 9.6 );
$arr[1]['name'] = 'New York';
$arr[1]['data'] = array( -0.2, 0.8, 5.7, 11.3, 17.0, 22.0, 24.8, 24.1, 20.1, 14.1, 8.6, 2.5 );
$arr[2]['name'] = 'Berlin';
$arr[2]['data'] = array( -0.9, 0.6, 3.5, 8.4, 13.5, 17.0, 18.6, 17.9, 14.3, 9.0, 3.9, 1.0 );
$arr[3]['name'] = 'London';
$arr[3]['data'] = array( 3.9, 4.2, 5.7, 8.5, 11.9, 15.2, 17.0, 16.6, 14.2, 10.3, 6.6, 4.8 );
echo json_encode($arr);
你把这段代码打印出来试试(结果和你的示例的结果是一样的),跟这个数组格式一样的再
json_encode
一下就得到了要求的格式了。
你的评论提到的问题应该是一个MySQL的问题,我一般是这么操作的。
$sql = mysql_query('我是SQL请求语句');
while ($item = mysql_fetch_array($sql)) {
$data[]['name'] = $item['name'];
//balba
}
大概就是这个样子,用
while
循环获取。
最终鬼畜之路
answered 11 years ago