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

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

PHP 使用 $_POST 數組過濾 JSON 數組

PHP 使用 $_POST 數組過濾 JSON 數組

PHP
長風秋雁 2023-07-21 18:03:20
我目前有一個包含車輛信息的 json 文件:{    "Inventory": [{            "id": "1",            "StockNumber": "1000",            "Make": "Ford",            "Model": "Mustang",            "Trim": "GT",            "Year": "2011",            "Color": "Red",            "Cylinders": "8",            "Transmission": "Manual"        }, {            "id": "2",            "StockNumber": "1001",            "Make": "Ford",            "Model": "Mustang",            "Trim": "GT",            "Year": "2012",            "Color": "Yellow",            "Cylinders": "8",            "Transmission": "Automatic"        }, {            "id": "3",            "StockNumber": "1002",            "Make": "Chevy",            "Model": "Camaro",            "Trim": "ZL1",            "Year": "2020",            "Color": "Red",            "Cylinders": "8",            "Transmission": "Manual"        }]}我試圖讓復選框按品牌、型號、年份、顏色等過濾結果...從選擇頁面中,我獲取復選框的值,并將其傳遞到搜索 php 頁面。這是傳遞到搜索頁面的數組。['模型' => ['野馬', '科邁羅'],'顏色' => ['紅色']];這應該返回 2 個結果:紅色野馬和紅色科邁羅。如果我使用array_filter,在選擇福特后,雪佛蘭車輛現在會被過濾掉。所以我可以選擇福特和紅色,我會得到預期的結果。但是,現在我無法選擇雪佛蘭,因為它已被過濾掉。所以我看不到紅色的福特和雪佛蘭車輛。我得到一個結果,一輛紅色野馬。如果我嘗試使用 array_push 將車輛添加到結果數組中,我可以添加福特和雪佛蘭,但選擇紅色不會過濾掉黃色野馬,因為黃色野馬是福特,并且它符合該條件。我得到 3 個結果,1 輛紅色野馬、1 輛黃色野馬和 1 輛紅色科邁羅。我正在努力使用傳入的數組來過濾 json 結果的邏輯。似乎我需要傳入"or"多個品牌以及"and"每個類別。福特或雪佛蘭和紅色。另一個例子可能是:福特或雪佛蘭和紅色或黃色和手冊。我根據以下回復更新了代碼:$make = ['Mustang', 'Camaro'];$color = ['Red'];$result = [];   foreach ($dataSource as $k => $data) {         foreach ($posts as $postKey => $postValue) {              // This does not.  Only filters on last array in loop     if (array_key_exists($postKey, $data) && in_array($data[$postKey],      $postValue)) {          $result[$k] = $data;        } else {      unset($result[$k]);            }         }       }     }如何以靜態示例的工作方式根據數組標準動態過濾該數組?
查看完整描述

1 回答

?
慕沐林林

TA貢獻2016條經驗 獲得超9個贊

您需要將 post 數組轉換為此結構以便于處理


 $posts = [

        'Model' => ['Mustang', 'Camero'],

        'Color' => ['Red']

    ];

然后使用 foreach 過濾器:


        $carJson = '{

    "Inventory": [{

            "id": "1",

            "StockNumber": "1000",

            "Make": "Ford",

            "Model": "Mustang",

            "Trim": "GT",

            "Year": "2011",

            "Color": "Red",

            "Cylinders": "8",

            "Transmission": "Manual"

        }, {

            "id": "2",

            "StockNumber": "1001",

            "Make": "Ford",

            "Model": "Mustang",

            "Trim": "GT",

            "Year": "2012",

            "Color": "Yellow",

            "Cylinders": "8",

            "Transmission": "Automatic"

        }, {

            "id": "3",

            "StockNumber": "1002",

            "Make": "Chevy",

            "Model": "Camaro",

            "Trim": "ZL1",

            "Year": "2020",

            "Color": "Red",

            "Cylinders": "8",

            "Transmission": "Manual"

        },

        {

            "id": "4",

            "StockNumber": "1005",

            "Make": "Chevy",

            "Model": "VW",

            "Trim": "ZL1",

            "Year": "2020",

            "Color": "Red",

            "Cylinders": "8",

            "Transmission": "Manual"

        }]

}';

    $cars = json_decode($carJson, true)['Inventory'];



    $posts = [

        'Model' => ['Mustang', 'Camero'],

        'Color' => ['Red']

    ];


    $result = [];


    foreach ($posts as $postKey => $postValue) {

        foreach ($cars as $k => $car) {

            if (array_key_exists($postKey, $car) && in_array($car[$postKey], $postValue)) {

                $result[$k] = $car;

            } else {

                unset($cars[$k]);

                unset($result[$k]);

            }

        }

    }


    print_r($result);



查看完整回答
反對 回復 2023-07-21
  • 1 回答
  • 0 關注
  • 191 瀏覽

添加回答

舉報

0/150
提交
取消
微信客服

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

幫助反饋 APP下載

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

公眾號

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