数组处理问题,求优化

飞凡的陀螺 2014-12-26 11:33:37
有一个这样查询出来的数组。

$result = [
['month'=>08,'price'=>218],
['month'=>12,'price'=>140],
];


最终需要转换成一个字符串,用于前台js
格式类似:[49.9, 71.5, 106.4, 129.2, 144.0, 176.0, 135.6, 148.5, 216.4, 194.1, null, null]
显示的是每月的销售情况,没有值就为null
比如一月份的price为49.9

我的做法:
感觉有点麻烦,求优化


//先构造类似 ['01'=>0,'02'=>0 .... '12'=>0] 这种格式的数组
$fullMonth = [];
for($i=1;$i<=12;$i++){
$fullMonth[str_pad($i,2,'0',STR_PAD_LEFT)] = 0;
}
// 遍历数组 对应月份有值就放到新建的数组里
$i = 0;
foreach($fullMonth as $month=>$value){
foreach($result as $record){
if($month == $record['month']){
$fullMonth[$month] = $record['price'];
}
}
$i++;
}
return '[' . implode(',',$fullMonth) . ']';
...全文
170 5 打赏 收藏 转发到动态 举报
写回复
用AI写文章
5 条回复
切换为时间正序
请发表友善的回复…
发表回复
xuzuning 2014-12-26
  • 打赏
  • 举报
回复
$r = array_fill(0, 12, null);
$result = [
    ['month'=> '08', 'price'=> 218],
    ['month'=> '12', 'price'=> 140],
];
foreach($result as $v) {
  $r[$v['month'] - 1] = $v['price'];
}
echo json_encode($r);
[null,null,null,null,null,null,null,218,null,null,null,140]
傲雪星枫 2014-12-26
  • 打赏
  • 举报
回复
为什么不用json格式?

$result = [
    ['month'=>08,'price'=>218],
    ['month'=>12,'price'=>140],
];
echo json_encode($result); // [{"month":0,"price":218},{"month":12,"price":140}]

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
 <head>
  <meta http-equiv="content-type" content="text/html; charset=utf-8">
  <title> New Document </title>
 </head>

 <body>
  <?php
    $result = [
        ['month'=>08,'price'=>218],
        ['month'=>12,'price'=>140],
    ];
  ?>
  <div id="result"></div>
  <script type="text/javascript">
  var result = <?php echo json_encode($result); ?>;
  var tmp = '';
  for(var i=0; i<result.length; i++){
      tmp += result[i].month + ' = ' + result[i].price + '<br>';
  }
  document.getElementById('result').innerHTML = tmp;
  </script>
 </body>
</html>
傲雪星枫 2014-12-26
  • 打赏
  • 举报
回复
這樣

<?php
$res = [['y'=>'2014-12-03','item'=>263],['y'=>'2014-12-04','item'=>168]];
$tmp = array();

foreach($res as $v){
	$tmp[$v['y']] = $v['item'];
}

$start = 1;
$end = 31;

$result = array();

for($i=$start; $i<=$end; $i++){
	$key = date('Y-m-d',strtotime('2014-12-'.$i));
	$item = null;
	if(isset($tmp[$key])){
		$item = $tmp[$key];
	}

	array_push($result, array('y'=>$key,'item'=>$item));
}

echo json_encode($result, JSON_PRETTY_PRINT);
?>


[
    {
        "y": "2014-12-01",
        "item": null
    },
    {
        "y": "2014-12-02",
        "item": null
    },
    {
        "y": "2014-12-03",
        "item": 263
    },
    {
        "y": "2014-12-04",
        "item": 168
    },
    {
        "y": "2014-12-05",
        "item": null
    },
    {
        "y": "2014-12-06",
        "item": null
    },
    {
        "y": "2014-12-07",
        "item": null
    },
    {
        "y": "2014-12-08",
        "item": null
    },
    {
        "y": "2014-12-09",
        "item": null
    },
    {
        "y": "2014-12-10",
        "item": null
    },
    {
        "y": "2014-12-11",
        "item": null
    },
    {
        "y": "2014-12-12",
        "item": null
    },
    {
        "y": "2014-12-13",
        "item": null
    },
    {
        "y": "2014-12-14",
        "item": null
    },
    {
        "y": "2014-12-15",
        "item": null
    },
    {
        "y": "2014-12-16",
        "item": null
    },
    {
        "y": "2014-12-17",
        "item": null
    },
    {
        "y": "2014-12-18",
        "item": null
    },
    {
        "y": "2014-12-19",
        "item": null
    },
    {
        "y": "2014-12-20",
        "item": null
    },
    {
        "y": "2014-12-21",
        "item": null
    },
    {
        "y": "2014-12-22",
        "item": null
    },
    {
        "y": "2014-12-23",
        "item": null
    },
    {
        "y": "2014-12-24",
        "item": null
    },
    {
        "y": "2014-12-25",
        "item": null
    },
    {
        "y": "2014-12-26",
        "item": null
    },
    {
        "y": "2014-12-27",
        "item": null
    },
    {
        "y": "2014-12-28",
        "item": null
    },
    {
        "y": "2014-12-29",
        "item": null
    },
    {
        "y": "2014-12-30",
        "item": null
    },
    {
        "y": "2014-12-31",
        "item": null
    }
]
傲雪星枫 2014-12-26
  • 打赏
  • 举报
回复
y加上引號,這樣才不會有notice

<?php
$res = [['y'=>'2014-12-03','item'=>263],['y'=>'2014-12-04','item'=>168]];
echo json_encode($res, JSON_PRETTY_PRINT);
?>


[
    {
        "y": "2014-12-03",
        "item": 263
    },
    {
        "y": "2014-12-04",
        "item": 168
    }
]
飞凡的陀螺 2014-12-26
  • 打赏
  • 举报
回复
进一步询问 已知
$res = [[y=>'2014-12-03','item'=>263],[y=>'2014-12-04','item'=>168]];
让变成如下格式
[
            {y: '2014-12-01', item: null},
            {y: '2014-12-02', item: null},
            {y: '2014-12-03', item: 263},
            {y: '2014-12-04', item: 168},
            {y: '2014-12-05', item: null},
             .....
             {y: '2014-12-31', item1:null},
]
1.算法是程序的灵魂,优秀的程序在对海量数据处理时,依然保持高速计算,就需要高效的数据结构和算法支撑。2.网上数据结构和算法的课程不少,但存在两个问题:1)授课方式单一,大多是照着代码念一遍,数据结构和算法本身就比较难理解,对基础好的学员来说,还好一点,对基础不好的学生来说,基本上就是听天书了2)说是讲数据结构和算法,但大多是挂羊头卖狗肉,算法讲的很少。 本课程针对上述问题,有针对性的进行了升级 3)授课方式采用图解+算法游戏的方式,让课程生动有趣好理解 4)系统全面的讲解了数据结构和算法, 除常用数据结构和算法外,还包括程序员常用10大算法:二分查找算法(非递归)、分治算法、动态规划算法、KMP算法、贪心算法、普里姆算法、克鲁斯卡尔算法、迪杰斯特拉算法、弗洛伊德算法、马踏棋盘算法。可以解决面试遇到的最短路径、最小生成树、最小连通图、动态规划等问题及衍生出的面试题,让你秒杀其他面试小伙伴3.如果你不想永远都是代码工人,就需要花时间来研究下数据结构和算法。教程内容:本教程是使用Java来讲解数据结构和算法,考虑到数据结构和算法较难,授课采用图解加算法游戏的方式。内容包括: 稀疏数组、单向队列、环形队列、单向链表、双向链表、环形链表、约瑟夫问题、栈、前缀、中缀、后缀表达式、中缀表达式转换为后缀表达式、递归与回溯、迷宫问题、八皇后问题、算法的时间复杂度、冒泡排序、选择排序、插入排序、快速排序、归并排序、希尔排序、基数排序(桶排序)、堆排序、排序速度分析、二分查找、插值查找、斐波那契查找、散列、哈希表、二叉树、二叉树与数组转换、二叉排序树(BST)、AVL树、线索二叉树、赫夫曼树、赫夫曼编码、多路查找树(B树B+树和B*树)、图、图的DFS算法和BFS、程序员常用10大算法、二分查找算法(非递归)、分治算法、动态规划算法、KMP算法、贪心算法、普里姆算法、克鲁斯卡尔算法、迪杰斯特拉算法、弗洛伊德算法马踏棋盘算法。学习目标:通过学习,学员能掌握主流数据结构和算法的实现机制,开阔编程思路,提高优化程序的能力。

21,892

社区成员

发帖
与我相关
我的任务
社区描述
从PHP安装配置,PHP入门,PHP基础到PHP应用
社区管理员
  • 基础编程社区
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧