亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

根據列值過濾關聯行,其中行位于 3d 數組的特定子數組中

根據列值過濾關聯行,其中行位于 3d 數組的特定子數組中

PHP
翻翻過去那場雪 2023-11-05 15:46:16
我正在嘗試 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 !== ''; }  ));
查看完整描述

4 回答

?
LEATH

TA貢獻1936條經驗 獲得超7個贊

您$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"

  }

}


查看完整回答
反對 回復 2023-11-05
?
互換的青春

TA貢獻1797條經驗 獲得超6個贊

因為它是一個嵌套數組,所以您需要走更長的路線并使用 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 值。


查看完整回答
反對 回復 2023-11-05
?
哆啦的時光機

TA貢獻1779條經驗 獲得超6個贊

由于您在過濾數組中有一個關聯數組,從技術上講它不是空的,這就是您的代碼不起作用的原因。


如果您希望過濾數組中的指定鍵(假設該鍵確實存在)不為空,只需傳遞該鍵值,如下所示:


$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"

  ]

]


查看完整回答
反對 回復 2023-11-05
?
胡說叔叔

TA貢獻1804條經驗 獲得超8個贊

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);

    }

}


查看完整回答
反對 回復 2023-11-05
  • 4 回答
  • 0 關注
  • 212 瀏覽

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號