Maison >développement back-end >tutoriel php >Comment implémenter le regroupement de données et les fonctions statistiques en PHP

Comment implémenter le regroupement de données et les fonctions statistiques en PHP

王林
王林original
2023-09-24 13:39:161199parcourir

Comment implémenter le regroupement de données et les fonctions statistiques en PHP

Comment implémenter le regroupement de données et les fonctions statistiques en PHP

Dans le processus de développement actuel, nous rencontrons souvent le besoin de regrouper et de compter les données. Qu'il s'agisse de regrouper des statistiques sur des données dans une base de données ou d'exploiter des données dans un tableau, PHP offre une multitude de fonctions et de méthodes pour répondre à nos besoins.

Ce qui suit montrera comment regrouper et compter les données d'une base de données et d'un tableau en PHP.

Regroupement de données et statistiques dans la base de données

Supposons que nous ayons un tableau de performance des élèves avec la structure suivante :

CREATE TABLE `scores` (
  `id` int(11) unsigned NOT NULL AUTO_INCREMENT,
  `student_id` int(11) NOT NULL,
  `subject` varchar(50) NOT NULL,
  `score` decimal(5,2) NOT NULL,
  PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;

Nous voulons calculer le score total et le score moyen de chaque élève. Vous pouvez utiliser le code suivant pour le regroupement et les statistiques :

// 连接数据库
$pdo = new PDO('mysql:host=localhost;dbname=test', 'username', 'password');

// 查询数据
$query = "SELECT student_id, SUM(score) AS total, AVG(score) AS average FROM scores GROUP BY student_id";
$stmt = $pdo->prepare($query);
$stmt->execute();
$results = $stmt->fetchAll(PDO::FETCH_ASSOC);

// 输出结果
foreach ($results as $result) {
    echo "学生ID:" . $result['student_id'] . ",总分:" . $result['total'] . ",平均分:" . $result['average'] . "<br>";
}

Dans le code ci-dessus, nous utilisons PDO pour nous connecter à la base de données, puis exécutons l'instruction de requête et stockons les résultats dans le tableau $results. Enfin, le score total et le score moyen de chaque élève sont affichés via la boucle foreach.

Groupe et statistiques des données du tableau

Supposons que nous ayons un tableau contenant un groupe d'élèves. Chaque élève a trois attributs : nom, âge et note, comme suit :

$students = [
    ['name' => '张三', 'age' => 18, 'score' => 85],
    ['name' => '李四', 'age' => 19, 'score' => 92],
    ['name' => '王五', 'age' => 20, 'score' => 78],
    ['name' => '赵六', 'age' => 18, 'score' => 89],
    ['name' => '钱七', 'age' => 19, 'score' => 95],
    ['name' => '孙八', 'age' => 20, 'score' => 82],
];

Nous voulons regrouper les élèves en fonction de leur âge, et Calculez les scores moyen et maximum des élèves de chaque groupe. Voici le code pour implémenter le regroupement et les statistiques :

// 按照年龄分组
$groups = [];
foreach ($students as $student) {
    $age = $student['age'];
    if (!isset($groups[$age])) {
        $groups[$age] = [];
    }
    $groups[$age][] = $student;
}

// 统计每个分组中的平均分和最高分
foreach ($groups as $age => $group) {
    $total = 0;
    $maxScore = 0;
    foreach ($group as $student) {
        $total += $student['score'];
        if ($student['score'] > $maxScore) {
            $maxScore = $student['score'];
        }
    }
    $average = $total / count($group);
    echo "年龄:" . $age . ",平均分:" . $average . ",最高分:" . $maxScore . "<br>";
}

Dans le code ci-dessus, nous utilisons d'abord la boucle foreach pour regrouper les étudiants en fonction de leur âge et les stocker dans le tableau $groups. Ensuite, il parcourt chaque groupe à travers une boucle foreach imbriquée, calcule le score moyen et le score le plus élevé, et génère enfin le résultat.

Grâce aux exemples de code ci-dessus, nous pouvons voir comment utiliser PHP pour implémenter des fonctions de regroupement de données et de statistiques. Que vous opériez sur des données dans une base de données ou sur des données dans un tableau, vous pouvez choisir la méthode appropriée pour l'implémenter en fonction de vos besoins. Ces fonctions sont très courantes dans le développement réel et ont de nombreuses applications dans des domaines tels que l'analyse de données et la génération de rapports.

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn