PHP Массив и foreach Расчет комбинации - PullRequest
0 голосов
/ 26 февраля 2020

В приложении для викторины я беру ответ пользователя, используя форму. Я получаю правильный ответ из таблицы базы данных. Я хочу сравнить правильный ответ с ответом пользователя и посчитать, сколько ответов было правильным и сколько ответов было неправильным.

Вот моя форма:

<form id="question" class="" action="quiz_ans.php" method="post">
    <table id="quiz-question" align="center" class="row-border compact order-column stripe">
        <input class="form-control" type="hidden" name="NumberofQuestions" id="NumberofQuestions" value="<?php echo $NumberofQuestions; ?>">
        <thead>
            <?php
                if($QuizQuestions) {
                    $i=1;
                    foreach($QuizQuestions as $row):
              ?>
            <tr>
                <th><?php echo $i; ?>. <?php echo $row->Question; ?>
                    <br>
                <?php if(isset($row->Screenshot)) { ?>
                    <img src="<?php echo htmlspecialchars($row->Screenshot); ?>" alt="test" height="300" width="980">
                <?php } ?>
                </th>
            </tr>
        </thead>
        <tbody>
            <?php if(isset($row->Option1)) { ?>
            <tr class="info">
                <td><input type="radio" name="AnswerId[<?php echo $row->Id; ?>]" value="0"><?php echo $row->Option1; ?></td>
            </tr>
            <?php } ?>
            <?php if(isset($row->Option2)) { ?>
            <tr class="info">
                <td><input type="radio" name="AnswerId[<?php echo $row->Id; ?>]" value="1"> <?php echo $row->Option2; ?></td>
            </tr>
            <?php } ?>
            <?php if(isset($row->Option3)) { ?>
            <tr>
                <td><input type="radio" name="AnswerId[<?php echo $row->Id; ?>]" value="2"> <?php echo $row->Option3; ?></td>
            </tr>
            <?php } ?>
            <?php if(isset($row->Option4)) { ?>
            <tr>
                <td><input type="radio" name="AnswerId[<?php echo $row->Id; ?>]" value="3"><?php echo $row->Option4; ?></td>
            </tr>
            <?php } ?>
            <tr>
                <td><label for="AnswerReason">Why?</label><input class="form-control" type="text" name="AnswerReason[]" id="AnswerReason" value=""></td>
            </tr>
            <?php if(isset($row->Id)) { ?>
            <tr>
                <td><input class="form-control" type="hidden" name="QuestionId[]" id="QuestionId" value="<?php echo $row->Id; ?>"></td>
            </tr>
            <?php } ?>


        </tbody>

    <?php
        $i++;
      endforeach;
      }
    ?>
    </table>
    <br>
    <input type="submit" name="submit" value="Submit" class="btn btn-success">
</form>

Я получаю ответ пользователя из формы отправки:

$NumberofQuestions = $_POST['NumberofQuestions'];
$ans = implode("", $_POST['AnswerId']);

Я получаю правильный ответ из таблицы базы данных :

 try {
   $sql = "CALL spQuizAnswers(:quiz_num)";
   $stmt = $pdo->prepare($sql);
   $stmt->bindParam(':quiz_num', $quiz_num, PDO::PARAM_STR, 50);
   $stmt->execute();
   $QuizAns=$stmt->fetchAll();
   $stmt->closeCursor();
 } catch (PDOException $e) {
   die("Error occurred:" . $e->getMessage());
}

Я сравниваю ответ пользователя и правильный ответ:

for ($i=0; $i<$NumberofQuestions; $i++) {
    if($QuizAns) {
        foreach($QuizAns as $row):
            if($row->CorrectAns == $ans[$i]){
                $right++;
            } elseif($ans[$i] == 4){
                $not_answered++;
            } else {
                $wrong++;
            }

        endforeach;
    }
}

$CorrectAnswer = $right;
$WrongAnswer = $wrong;
$NotAnswered = $not_answered;
$TotalQuestion = $right+$wrong+$not_answered;

Это не дает правильного расчета. Для 5 вопросов это дает $ TotalQuestion = 25. Как я могу добиться правильного расчета? Любая помощь будет высоко ценится.

...