为键创建值为[1]、为值创建值为[2]的新数组


create new array with value[1] for key and value[2] for value

我有一个保存为的日志文件

{time} | {name} | {value1}
{time} | {name} | {value2}
{time} | {name2} | {value3}
{time} | {name3} | {value4}

{time}是一个时间戳,单位为"自Unix大纪元以来的秒数"

日志文件是逐行写入的,所以最新的日志行在底部,

我正在尝试将这些值分类到php数组中。。。。

假设我们有

{time} | Steve | Pizza
{time} | Steve | Kebab
{time} | Steve | Burger
{time} | John | Kebab
{time} | John | Ice-Cream
{time} | Dave | Pizza
{time} | Derek | Ice-Cream
{time} | Derek | Fanta

我已经分解成数组$lines

这就是我可以用来获取变量的东西。。。。

echo $lines[0][1] . "," . $lines[0][2];  // this will print ' Steve,Pizza '
echo $lines[3][2];  // this will print ' Kebab '

我正在尝试以某种方式编码一个数组,使用"$lines[$x][1]"作为数组键,使用"$lines[$x][2]"作为数组值,这样我就可以调用:

print_r($new_array);

获取:

array
     (
  [Steve] => Pizza
          => Kebab
          => Burger
     )
     (
  [John] => Kebab
         => Ice-Cream
     )
     (
  [Dave] => Pizza
     )
     (
  [Derek] => Ice-Cream
          => Fanta
     )

这样做的原因是我需要显示一个看起来像这样的小表格。。。。

 _________________________________________
|       Steve       |      Pizza          |
|                   |      Kebab          |
|___________________|_____ Burger ________|
|       John        |      Kebab          |
|___________________|_____ Ice-Cream _____|
|______ Dave _______|_____ Pizza _________|
|       Derek       |      Ice-Cream      |
|___________________|_____ Fanta _________|

数组$lines已格式化为删除所有超过24小时的"日志行"。。。。

所以我认为我不需要限制数组密钥{name}的数量

提前感谢您的任何建议。。。。已经为此尝试了所有逻辑解决方案:rant:

没有完全测试,但尝试:

$new = array();
foreach($lines as $line)
{
    $new[$line[1]][] = $line[2];
}
print_r($new);

由DJ-p.I.M.p.编辑…

$new = array();
foreach($lines as $line)
{
$new[$line[1]][] = $line[2];
}
// print_r($new);

foreach($new as $key => $news) {
echo $key . "<br>";
foreach($news as $k => $v) {
echo $news[$k] . "<br>";
}
}

正如我的问题所问的那样。。。。值得称赞的是,最初的想法@Aaron:)

在子数组中添加共享同一密钥的值的不同变体:

$result = array();
for ($lines as $line) {
    if (!isset($result[$line[1]])) {
        $result[$line[1]] = array();
    }
    $result[$line[1]][] = $line[2];
}