根据列值过滤关联行,其中行位于 3d 数组的特定子数组中

我正在尝试 array_filter() 删除空白的嵌套数组,但我只取回所有嵌套数组。我知道我用错了,但看到了类似的案例,就像我正在尝试的那样。


这是数据:


[

    'ticket_number' => 'sdfsdfsdf 2',

    'strategy_id' => '5',

    'journal_entries_strategy_conditions' => [

        (int) 0 => [

            'strategies_condition_id' => ''

        ],

        (int) 1 => [

            'strategies_condition_id' => '1'

        ]

    ],

    'timeframe' => '',

]

我想删除'strategies_condition_id' => ''但我得到的只是


[

    (int) 0 => [

        'strategies_condition_id' => ''

    ],

    (int) 1 => [

        'strategies_condition_id' => '1'

    ]

]

我认为我使用它是正确的:


debug(

  array_filter(

    $data['journal_entries_strategy_conditions'], 

    function($value) { return !is_null($value) && $value !== ''; }

  )

);


翻翻过去那场雪
浏览 153回答 4
4回答

LEATH

您$value传递给过滤函数的也是一个关联数组。因此,您必须检查“值的值”,使用current()使过滤函数与键名无关,从而在需要时使此代码可移植。我将函数参数命名为$entry避免混淆:$data= [    'ticket_number' => 'sdfsdfsdf 2',    'strategy_id' => '5',    'journal_entries_strategy_conditions' => [        (int) 0 => [            'strategies_condition_id' => ''        ],        (int) 1 => [            'strategies_condition_id' => '1'        ]    ],    'timeframe' => '',];var_dump(    array_filter(        $data['journal_entries_strategy_conditions'],        function($entry) {            $value = current($entry);            return !is_null($value) && $value !== '';        }    ));结果是:array(1) {  [1]=>  array(1) {    ["strategies_condition_id"]=>    string(1) "1"  }}

互换的青春

因为它是一个嵌套数组,所以您需要走更长的路线并使用 array_column,然后用键的交集替换数组子数组。$filtered = array_filter(array_column($arr['journal_entries_strategy_conditions'], 'strategies_condition_id'));$arr['journal_entries_strategy_conditions'] = array_intersect_key($arr['journal_entries_strategy_conditions'], $filtered);var_dump($arr);https://3v4l.org/iC66a通过将其设为单行,可以使其可读性更差。并且您不需要为此使用自定义函数。Array_filter 默认删除 '' 和 null 值。

哆啦的时光机

由于您在过滤数组中有一个关联数组,从技术上讲它不是空的,这就是您的代码不起作用的原因。如果您希望过滤数组中的指定键(假设该键确实存在)不为空,只需传递该键值,如下所示:$data = [        (int) 0 => [            'strategies_condition_id' => '',            'test' => '',            'asd' => 'asd'        ],        (int) 1 => [            'strategies_condition_id' => '1'        ]    ];$key = 'strategies_condition_id';$result = array_filter($data, function($value) use ($key) {dump($value); return !is_null($value[$key]) && $value[$key] !== ''; });输出:array:1 [  1 => array:1 [    "strategies_condition_id" => "1"  ]]数组0被跳过,因为它的strategies_condition_id键为空。还有另一种简单的方法来检查过滤数组中是否有空值:$data = [        (int) 0 => [            'strategies_condition_id' => '',            'test' => 'test'        ],        (int) 1 => [            'strategies_condition_id' => '1'        ],        (int) 2 => [            'strategies_condition_id' => '2',            'test' => ''        ]    ];array_filter($data, function($value) { return !in_array('',$value); });输出:array:1 [  1 => array:1 [    "strategies_condition_id" => "1"  ]]

胡说叔叔

array_filter()在特定的第一级元素上使用单个元素即可完成这项工作。在函数的回调内部,不需要任何函数调用;只需访问目标关联子数组值并检查它是否为真。这与函数式编码一样简单。代码:(演示)$array['journal_entries_strategy_conditions'] = array_filter(    $array['journal_entries_strategy_conditions'],    fn($row) => $row['strategies_condition_id']);与经典循环等效的内容可以unset()有条件地使用。(演示)foreach ($array['journal_entries_strategy_conditions'] as $i => $row) {    if (!$row['strategies_condition_id']) {        unset($array['journal_entries_strategy_conditions'][$i]);    }}或者,如果您希望有一个重新索引的子数组,array_splice()这会很有帮助。(演示)foreach ($array['journal_entries_strategy_conditions'] as $i => $row) {    if (!$row['strategies_condition_id']) {        array_splice($array['journal_entries_strategy_conditions'], $i, 1);    }}
打开App,查看更多内容
随时随地看视频慕课网APP