- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有两个数组,我想合并它们,但合并日期相同的地方。我设法合并它们,但如果日期相同,它将它们合并为不同的条目。这是我的 2 个数组:arr1:
[{"y":"2015-03-05","item1":"850","item2":"0"},
{"y":"2015-03-19","item1":"8377","item2":"0"},
{"y":"2015-05-27","item1":"1037","item2":"0"},
{"y":"2015-10-15","item1":"5402","item2":"0"}]
arr2:
[{"y":"2015-04-29","item1":"0","item2":"1008"},
{"y":"2015-05-27","item1":"0","item2":"25"}]
当我使用 $arr = array_merge($arr1, $arr2);
时,它会合并它们,但日期很常见,在我的情况下 2015-05-27 我想将它们合并到 "y":"2015-05-27","item1":"1037","item2":"25"
最佳答案
您可以尝试这种方法,将日期的项目数组映射到具有 date 键的关联数组,然后仅添加具有非零值的其他项目。请参阅代码中的注释:
// Make PHP arrays of JSON
$items1 = json_decode('[
{"y":"2015-03-05","item1":"850","item2":"0"},
{"y":"2015-03-19","item1":"8377","item2":"0"},
{"y":"2015-05-27","item1":"1037","item2":"0"},
{"y":"2015-10-15","item1":"5402","item2":"0"}]', true);
$items2 = json_decode('[
{"y":"2015-04-29","item1":"0","item2":"1008"},
{"y":"2015-05-27","item1":"0","item2":"25"}]', true);
// Define an associative array like:
// [
// '<date>' => [ 'item1' => '<n>', 'item2' => "<n>" ],
// ...
// ]
$itemsPerDay = [];
// Loop arrays
foreach (array_merge($items1, $items2) as $array) {
$date = $array['y']; // Get date
if (!isset($itemsPerDay[$date])) {
// If array for date not set in associative array, use full array
$itemsPerDay[$date] = $array;
}
else {
// If array for date already exists, merge only items having a
// non-empty value
$nonEmptyValues = array_filter($array, function($w) { return !empty($w); });
$itemsPerDay[$date] = array_merge($itemsPerDay[$date], $nonEmptyValues);
}
}
// Get values part of associative array
$itemsPerDay = array_values($itemsPerDay);
// Output JSON
echo json_encode($itemsPerDay);
输出(为了清晰起见,缩进):
[{"y": "2015-03-05", "item1": "850", "item2": "0"},
{"y": "2015-03-19", "item1": "8377", "item2": "0"},
{"y": "2015-05-27", "item1": "1037", "item2": "25"},
{"y": "2015-10-15", "item1": "5402", "item2": "0"},
{"y": "2015-04-29", "item1": "0", "item2": "1008"}]
关于php - 如何合并两个数组,但在日期常见的地方合并它们,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/29952168/
按照目前的情况,这个问题不适合我们的问答形式。我们希望答案得到事实、引用或专业知识的支持,但这个问题可能会引发辩论、争论、投票或扩展讨论。如果您觉得这个问题可以改进并可能重新打开,visit the
操作无法完成。 Places API 库中发生内部错误。如果您认为此错误代表错误,请使用我们社区和支持页面 (https://developers.google.com/places/support)
我正在尝试在我的项目中使用 google places,我将其设置在 fragment 中而不是 Activity 中,我的自动完成 fragment 在 fragment 中。但是,当我尝试搜索它时
我的目的是使用R来查询google api。 我有一个地址和名称列表(属于商店、餐馆等),我需要为每个地址和名称存储: “纬度”、“经度”、“业务类型” 我的想法是使用 google place ap
我正在寻找设置一个自动完成的谷歌地方小部件。 我有一个带有“searchFieldText”id 的输入类型文本。 这是我的 JS 代码: var inputsec = document.getEle
是否可以使用图形 API(或地址/ zip )按纬度/经度和半径获取地点?我在文档中的任何地方都看不到它 最佳答案 搜索 URL 的以下格式将返回某个位置附近的地点列表: https://graph.
我正在探索 Google API,主要是 Places API。由于对 Google Places API 的请求数限制为 100,000,因此我正在寻找方法来最大限度地减少发送到 API 的请求数。
伙计们,我在我的应用程序中有一个功能,可以使用 GetFiles 在特定目录中搜索特定文件。方法 System.IO.Directory.GetFiles(string path, string
我已经在 Laravel 5.3 上使用 where 查询成功创建了许多函数,但是这次发生了一些奇怪的事情。 public function show($id){ $artikel = Art
我正在为我的 iPhone 应用程序使用 Facebook 图形 API 来获取附近地点的列表,我使用带有一些参数的“搜索”请求。我得到的响应是一个包含以下信息的地点列表:“纬度”、“经度”、“名称”
我有一个 Android 应用程序,我在其中使用 Google map 显示附近的地方,如加油站、药店等。我正在使用 map 和地点 API。 https://maps.googleapis.com/
我是一名优秀的程序员,十分优秀!