Использование значений в одном ассоциативном массиве для проверки значений в другом ассоциативном массиве - PullRequest
0 голосов
/ 17 января 2020

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


while ($row = $grade->fetch(PDO::FETCH_ASSOC)) {
        $data = $row;
        var_export($data);
    } //fetches the grading system whose array is seen below

while($row = $stmt->fetch(PDO::FETCH_ASSOC)){
    $scores = $row;
    var_export($scores);
}// fetches scores of students in test
foreach($data as $key=> $grading) {
    foreach($scores as $key =>$values){


    if($values["marks"]>=$grading["grade_min"] && $values["marks"]<=$grading["grade_max"])
    print_r($values["marks"]);
    print_r($grading["grade"]);
    print_r($grading["remarks"]);
}
} Am trying to iterate each scores against the grading system but not successful, please help.

Array
(
    [0] => Array
        (
            [id] => 2
            [grade_min] => 1
            [grade_max] => 39
            [grade] => E
            [remarks] => Fail
        )

    [1] => Array
        (
            [id] => 3
            [grade_min] => 40
            [grade_max] => 49
            [grade] => D
            [remarks] => Pass
        )

    [2] => Array
        (
            [id] => 4
            [grade_min] => 50
            [grade_max] => 59
            [grade] => C
            [remarks] => Credit
        )

    [3] => Array
        (
            [id] => 5
            [grade_min] => 60
            [grade_max] => 69
            [grade] => B
            [remarks] => Good
        )

    [4] => Array
        (
            [id] => 6
            [grade_min] => 70
            [grade_max] => 79
            [grade] => A
            [remarks] => Very Good
        )

    [5] => Array
        (
            [id] => 7
            [grade_min] => 80
            [grade_max] => 100
            [grade] => A+
            [remarks] => Excellent
        )

)
Array
(
    [0] => Array
        (
            [id] => 2
            [grade_min] => 1
            [grade_max] => 39
            [grade] => E
            [remarks] => Fail
        )

    [1] => Array
        (
            [id] => 3
            [grade_min] => 40
            [grade_max] => 49
            [grade] => D
            [remarks] => Pass
        )

    [2] => Array
        (
            [id] => 4
            [grade_min] => 50
            [grade_max] => 59
            [grade] => C
            [remarks] => Credit
        )

    [3] => Array
        (
            [id] => 5
            [grade_min] => 60
            [grade_max] => 69
            [grade] => B
            [remarks] => Good
        )

    [4] => Array
        (
            [id] => 6
            [grade_min] => 70
            [grade_max] => 79
            [grade] => A
            [remarks] => Very Good
        )

    [5] => Array
        (
            [id] => 7
            [grade_min] => 80
            [grade_max] => 100
            [grade] => A+
            [remarks] => Excellent
        )

)

Массив баллов выглядит следующим образом:

Array
(
    [0] => 35
    [1] => 48
    [2] => 57
    [3] => 78
    [4] => 75
    [5] => 89
)

Я хочу перебрать массив этих баллов с массивом системы оценок и вернуть только «оценку» и «замечания», которые совпадают, где баллы находятся между «grade_min» и «grade_max»

1 Ответ

0 голосов
/ 18 января 2020

Лучше перебрать оценки, а затем повторить оценку, чтобы найти ту, которой принадлежит оценка.

Кроме того, ваш if не имеет фигурных скобок, поэтому он будет выполнять только первое предложение после него.

// fetches the grading system whose array is seen below
while ($row = $grade->fetch(PDO::FETCH_ASSOC)) {
    $data = $row;
    // var_export($data); // No need to se this anymore
}

// fetches scores of students in test
while($row = $stmt->fetch(PDO::FETCH_ASSOC)){
    $scores = $row;
    // var_export($scores); // No need to see this anymore
}

// Iterate scores first (I don't know if you need the index or not)
foreach($scores as $scoreIndex => $score) {
    // Search grading for this score (Index not needed here, just values)
    foreach($data as $grading) {
        if($score['marks'] >= $grading['grade_min'] && $score['marks'] <= $grading['grade_max']) {
            // Score is inside this grading
            // Echo, print or assign what you need here

            // Then exit the loop for grading
            break;
        }
    }
}

Исходя из вашего вывода для $scores, этот массив является просто одним значением, без ассоциативного массива, поэтому значение l oop должно быть:

// Iterate scores first (I don't know if you need the index or not)
foreach($scores as $scoreIndex => $score) {
    // Search grading for this score (Index not needed here, just values)
    foreach($data as $grading) {
        // $score is an integer, not an array
        if($score >= $grading['grade_min'] && $score <= $grading['grade_max']) {
            // Score is inside this grading
            // Echo here what you need

            // Then exit the loop for grading
            break;
        }
    }
}
...