PHP怎么往间隔数组中添加数据
现有一数组如下:
[site003] => Array
<code> ( [0] => Array ( [key] => site003 [riqi] => 2016-06-14 [shijian] => 00 [num] => 1 ) [1] => Array ( [key] => site003 [riqi] => 2016-06-14 [shijian] => 04 [num] => 2 ) [2] => Array ( [key] => site003 [riqi] => 2016-06-14 [shijian] => 07 [num] => 6 ) )</code>
由于时间shijian字段00到-04点中间没有01,02,03时间点,所以想对01,02,03时间点组装数据的num字段补充为0,
后者04-07中间时间点05,06也对num的时间点补充数组为0
麻烦各路高手指点迷津!小弟在此谢谢!
回复内容:
现有一数组如下:
[site003] => Array
<code> ( [0] => Array ( [key] => site003 [riqi] => 2016-06-14 [shijian] => 00 [num] => 1 ) [1] => Array ( [key] => site003 [riqi] => 2016-06-14 [shijian] => 04 [num] => 2 ) [2] => Array ( [key] => site003 [riqi] => 2016-06-14 [shijian] => 07 [num] => 6 ) )</code>
由于时间shijian字段00到-04点中间没有01,02,03时间点,所以想对01,02,03时间点组装数据的num字段补充为0,
后者04-07中间时间点05,06也对num的时间点补充数组为0
麻烦各路高手指点迷津!小弟在此谢谢!
首先你需要确定你是否需要插入相关数据以及你插入的数据的方案,如果你不能确定中间缺失的shijian字段的始末的话,需要遍历这个数组去确定,然后将没有的字段加进去,然后用usort进行排序。
也可以在插入的时候决定你插入的位置,但是由于你插入会影响你数组的下标,所以还是上面第一个方法比较方便。
参考代码
<?php $max_shijian = date("H"); // 填充主方法 $fill_date = function ($input,$key) use($max_shijian) { $hours = range(0,$max_shijian); $riqi = null; // 筛选出不存在的时间 // http://php.net/manual/zh/function.array-map.php array_map(function(&$item,$key) use(&$hours,&$riqi){ empty($riqi) and $riqi = $item['riqi']; unset($hours[intval($item['shijian'])]); },$input); // 填充不存在的时间 foreach ($hours as $hour) { $input[] = [ 'key' => $key, 'riqi' => $riqi, 'shijian' => getFullHour($hour), 'num' => 0, ]; } // 排序 // http://php.net/manual/zh/function.usort.php usort($input,function($a,$b){ return (intval($a['shijian'])<intval($b['shijian']))?-1:1; }); return $input; }; // 将小时补全为2位 function getFullHour($hour){ return (strlen($hour)==1)?("0".$hour):$hour; } $json = '{"site001":[{"key":"site001","riqi":"2016-06-14","shijian":"00","num":"10"},{"key":"site001","riqi":"2016-06-14","shijian":"01","num":"4"},{"key":"site001","riqi":"2016-06-14","shijian":"02","num":"1"},{"key":"site001","riqi":"2016-06-14","shijian":"03","num":"3"},{"key":"site001","riqi":"2016-06-14","shijian":"04","num":"2"},{"key":"site001","riqi":"2016-06-14","shijian":"05","num":"1"},{"key":"site001","riqi":"2016-06-14","shijian":"07","num":"9"},{"key":"site001","riqi":"2016-06-14","shijian":"08","num":"2"}],"site002":[{"key":"site002","riqi":"2016-06-14","shijian":"00","num":"3"},{"key":"site002","riqi":"2016-06-14","shijian":"01","num":"13"},{"key":"site002","riqi":"2016-06-14","shijian":"02","num":"8"},{"key":"site002","riqi":"2016-06-14","shijian":"03","num":"23"},{"key":"site002","riqi":"2016-06-14","shijian":"04","num":"14"},{"key":"site002","riqi":"2016-06-14","shijian":"05","num":"6"},{"key":"site002","riqi":"2016-06-14","shijian":"06","num":"4"},{"key":"site002","riqi":"2016-06-14","shijian":"07","num":"7"},{"key":"site002","riqi":"2016-06-14","shijian":"08","num":"18"},{"key":"site002","riqi":"2016-06-14","shijian":"09","num":"6"}],"site003":[{"key":"site003","riqi":"2016-06-14","shijian":"00","num":"1"},{"key":"site003","riqi":"2016-06-14","shijian":"04","num":"2"},{"key":"site003","riqi":"2016-06-14","shijian":"07","num":"6"}],"site004":[{"key":"site004","riqi":"2016-06-14","shijian":"00","num":"3"},{"key":"site004","riqi":"2016-06-14","shijian":"02","num":"1"},{"key":"site004","riqi":"2016-06-14","shijian":"03","num":"4"},{"key":"site004","riqi":"2016-06-14","shijian":"04","num":"7"},{"key":"site004","riqi":"2016-06-14","shijian":"05","num":"4"},{"key":"site004","riqi":"2016-06-14","shijian":"06","num":"2"}]}'; $data = json_decode($json,true); foreach ($data as $key => $value) { $data[$key] = call_user_func($fill_date,$value,$key); } print_r($data); ?>
array_map
usort
我说说我理解的思路,首先要先取你这个数组中shijian
字段的最大值,然后根据最大值循环填充。
你试下以下方法,
主要采用的思路是:
1.先从给定的数组中过滤出最大的shijian值,同时存储已经存在的时间值,
2.添加小于最大shijian值且不存在数组中的数据
<code> $srcArray = array (array( 'key' => 'site003', 'riqi'=> '2016-06-14', 'shijian' => 00, 'num' => 1, ) ,array ( 'key' => 'site003', 'riqi' => '2016-06-14', 'shijian' => 02, 'num'=> 2 ) ,array ( 'key' => 'site003', 'riqi' => '2016-06-14', 'shijian' => 04, 'num'=> 2 ) ); $data=array(-1); foreach($srcArray as $key=>$innerArray){ array_push($data,$innerArray['shijian']); if($innerArray['shijian'] > $data[0]){ $data[0] = intval($innerArray['shijian']); } } print_r($data); for($index = 0;$index<$data[0];$index++){ $exits= !array_search(intval($index),$data); if($exits){ $temp = array( 'key' => 'site003', 'riqi'=> '2016-06-14', 'shijian' => $index<10?'0'.$index:$index, 'num' => 0, ); array_push($srcArray,$temp); } } print_r($srcArray);</code>

熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

AI Hentai Generator
免費產生 AI 無盡。

熱門文章

熱工具

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強大的PHP整合開發環境

Dreamweaver CS6
視覺化網頁開發工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

熱門話題

PHP 8.4 帶來了多項新功能、安全性改進和效能改進,同時棄用和刪除了大量功能。 本指南介紹如何在 Ubuntu、Debian 或其衍生版本上安裝 PHP 8.4 或升級到 PHP 8.4

Visual Studio Code,也稱為 VS Code,是一個免費的原始碼編輯器 - 或整合開發環境 (IDE) - 可用於所有主要作業系統。 VS Code 擁有大量針對多種程式語言的擴展,可以輕鬆編寫

本教程演示瞭如何使用PHP有效地處理XML文檔。 XML(可擴展的標記語言)是一種用於人類可讀性和機器解析的多功能文本標記語言。它通常用於數據存儲

JWT是一種基於JSON的開放標準,用於在各方之間安全地傳輸信息,主要用於身份驗證和信息交換。 1.JWT由Header、Payload和Signature三部分組成。 2.JWT的工作原理包括生成JWT、驗證JWT和解析Payload三個步驟。 3.在PHP中使用JWT進行身份驗證時,可以生成和驗證JWT,並在高級用法中包含用戶角色和權限信息。 4.常見錯誤包括簽名驗證失敗、令牌過期和Payload過大,調試技巧包括使用調試工具和日誌記錄。 5.性能優化和最佳實踐包括使用合適的簽名算法、合理設置有效期、

字符串是由字符組成的序列,包括字母、數字和符號。本教程將學習如何使用不同的方法在PHP中計算給定字符串中元音的數量。英語中的元音是a、e、i、o、u,它們可以是大寫或小寫。 什麼是元音? 元音是代表特定語音的字母字符。英語中共有五個元音,包括大寫和小寫: a, e, i, o, u 示例 1 輸入:字符串 = "Tutorialspoint" 輸出:6 解釋 字符串 "Tutorialspoint" 中的元音是 u、o、i、a、o、i。總共有 6 個元

靜態綁定(static::)在PHP中實現晚期靜態綁定(LSB),允許在靜態上下文中引用調用類而非定義類。 1)解析過程在運行時進行,2)在繼承關係中向上查找調用類,3)可能帶來性能開銷。

PHP的魔法方法有哪些? PHP的魔法方法包括:1.\_\_construct,用於初始化對象;2.\_\_destruct,用於清理資源;3.\_\_call,處理不存在的方法調用;4.\_\_get,實現動態屬性訪問;5.\_\_set,實現動態屬性設置。這些方法在特定情況下自動調用,提升代碼的靈活性和效率。
