Фильтр массива JSON данных с ценовым параметром - PullRequest
0 голосов
/ 18 марта 2020

У меня есть данные JSON, и я использую этот код для соответствия названию. Это работает, но теперь я хочу go сделать еще один шаг и перечислить все продукты, которые ниже некоторой цены, или выше некоторой цены, или равны некоторой цене

$json = '[{
    "id": 2042049298481,
    "title": "Test Product 53",
    "variants": [{
        "id": 15733087797297,
        "title": "Default Title",
        "price": "100.00",
        "sku": "no"
    }]
}, {
    "id": 2196682342449,
    "title": "its test yar",
    "variants": [{
        "id": 16385289879601,
        "title": "Default Title",
        "price": "144.00",
        "sku": "no"
    }]
}, {
    "id": 4175970041905,
    "title": "uhjkjhkhk",
    "variants": [{
        "id": 30302326554673,
        "title": "Default Title",
        "price": "1000.00",
        "sku": "10"
    }]
}, {
    "id": 4183828791345,
    "title": "kaminsss",
    "variants": [{
        "id": 30346449518641,
        "title": "Default Title",
        "price": "111.00",
        "sku": "no"
    }]
}, {
    "id": 4247884890161,
    "title": "hellooo",
    "variants": [{
        "id": 30579860832305,
        "title": "Default Title",
        "price": "1111.00",
        "sku": "no"
    }]
}, {
    "id": 4248143822897,
    "title": "10oct latest collection",
    "variants": [{
        "id": 31157780938801,
        "title": "50",
        "price": "111.00",
        "sku": "no-1"
    }, {
        "id": 31157802270769,
        "title": "60",
        "price": "101.00",
        "sku": ""
    }, {
        "id": 31157804761137,
        "title": "70",
        "price": "111.00",
        "sku": ""
    }]
}, {
    "id": 4284600746033,
    "title": "18oct2019",
    "variants": [{
        "id": 31595410030641,
        "title": "120 / black",
        "price": "100.00",
        "sku": "10"
    }]
}, {
    "id": 4285596860465,
    "title": "test2222",
    "variants": [{
        "id": 30877916921905,
        "title": "Default Title",
        "price": "111.00",
        "sku": "no"
    }]
}]';
$array = json_decode($json,1);
$filter_name ='title';
$filter_value ='Test';
$expected88 = array_filter($array, function($el) use ($filter_value, $filter_name) {
       return ($el[$filter_name] >= $filter_value);

}); 

echo json_encode($expected88,true);

Это работает безупречно для title, но мы хотим фильтровать на основе variant price. Для одного варианта может быть несколько цен, и если $filter_value больше, равно или меньше любого, это может произойти.

Например, пользователь может искать товар, минимальная цена которого равна 50, поэтому В случае, если какой-либо вариант соответствует критериям, он будет перечислять эти продукты, или пользователь может искать, что цены всех вариантов должны быть меньше 50.

Мы пробовали вот так

$expected = array_filter($array, function ($var) use ($filter_value) {
    return ($var[$filter_name] >= $filter_value);
});

, но это не работает. Мы попробовали foreach и протестировали снова, но это всегда давало пустой результат

1 Ответ

0 голосов
/ 18 марта 2020

Здесь возможно решение

$filter_name ='variants';
$filter_value = 200;
$filter_field = "price";


$expected88 = array_filter($array, function($el) use ($filter_value, $filter_name, $filter_field) {
       return ((int)$el[$filter_name][0][$filter_field] >= (int)$filter_value);
}); 
...