Table des matières
回复讨论(解决方案)
Maison développement back-end tutoriel php 关于PHP的2个数组之间统计数量

关于PHP的2个数组之间统计数量

Jun 23, 2016 pm 01:18 PM




求救各位大神帮帮!
现在要做的就是,有一个调查问卷,然后要统计别人答题的情况,例如ABC分别多少人选择这样
第一个图是别人提交上来我数据库里面的内容,反序列化后,存在一个数组里面
第二个图是题目和选项
我不知道把数据这样分配在2个数组合不合适?
做统计的话,程序应该怎么写比较合适!
想了好几天。。。


回复讨论(解决方案)

这个在数据库里通过分组查询就可以了
没必要拿出来用 php 做

如果一定想要用 php 数组做,那么请贴出用 var_export 输出的测试数据




数据库中的表里面的问题的设置表格和别人提交上来的表格分别是这样的,不知道怎么下手,还有姓名,留言,电话等这些字段都是不统计的,,,想了好几天总是找不到连接点,,,

array (size=4)
  0 => 
    array (size=8)
      0 => 
        array (size=2)
          'name' => string '姓名' (length=6)
          'value' => string '123' (length=3)
      1 => 
        array (size=2)
          'name' => string '留言内容' (length=12)
          'value' => string '123' (length=3)
      2 => 
        array (size=2)
          'name' => string '联系电话' (length=12)
          'value' => string '9896' (length=4)
      3 => 
        array (size=2)
          'name' => string '性别' (length=6)
          'value' => string '女' (length=3)
      4 => 
        array (size=2)
          'name' => string '接下来的时间,您是选择就业、创' (length=45)
          'value' => string '就业' (length=6)
      5 => 
        array (size=2)
          'name' => string '您的就业择业方向是?(多选)' (length=42)
          'value' => string '
旅游交通民航业,
餐饮行业,
其他
' (length=49)
      6 => 
        array (size=2)
          'name' => string '您对刚就业工资要求是?' (length=33)
          'value' => string '2000-2500' (length=9)
      7 => 
        array (size=2)
          'name' => string '您所学的专业是?(多选)' (length=36)
          'value' => string '经管类,建工类,化工、医药类' (length=38)
  1 => 
    array (size=5)
      0 => 
        array (size=2)
          'name' => string '昵称' (length=6)
          'value' => string '哈哈哈' (length=9)
      1 => 
        array (size=2)
          'name' => string '留言内容' (length=12)
          'value' => string '嘿嘿' (length=6)
      2 => 
        array (size=2)
          'name' => string '联系电话' (length=12)
          'value' => string '111111111121' (length=12)
      3 => 
        array (size=2)
          'name' => string '性别' (length=6)
          'value' => string '男' (length=3)
      4 => 
        array (size=2)
          'name' => string '你喜欢常去哪个网站你喜欢常去哪' (length=45)
          'value' => string '淘宝淘宝淘宝淘宝淘宝淘宝淘宝淘宝
' (length=53)
  2 => 
    array (size=4)
      0 => 
        array (size=2)
          'name' => string '昵称' (length=6)
          'value' => string '人为财死鸟为食亡' (length=24)
      1 => 
        array (size=2)
          'name' => string '留言内容' (length=12)
          'value' => string '什么意思啊' (length=15)
      2 => 
        array (size=2)
          'name' => string '联系电话' (length=12)
          'value' => string '13088888888' (length=11)
      3 => 
        array (size=2)
          'name' => string '性别' (length=6)
          'value' => string '男' (length=3)
  3 => 
    array (size=4)
      0 => 
        array (size=2)
          'name' => string '昵称' (length=6)
          'value' => string '什么' (length=6)
      1 => 
        array (size=2)
          'name' => string '留言内容' (length=12)
          'value' => string '哈哈哈哈哈哈' (length=18)
      2 => 
        array (size=2)
          'name' => string '联系电话' (length=12)
          'value' => string '12345597744' (length=11)
      3 => 
        array (size=2)
          'name' => string '性别' (length=6)
          'value' => string '女' (length=3)



-------------------------------------


array (size=5)
  '性别' => 
    array (size=2)
      0 => string '男' (length=3)
      1 => string '女' (length=3)
  '接下来的时间,您是选择就业、创业?' => 
    array (size=3)
      0 => string '就业' (length=6)
      1 => string '创业' (length=6)
      2 => string '升学读书' (length=12)
  '您的就业择业方向是?(多选)' => 
    array (size=9)
      0 => string 'IT与通讯业' (length=14)
      1 => string '金融、证券、保险业' (length=27)
      2 => string '房地产业' (length=12)
      3 => string '医药食品业' (length=15)
      4 => string '旅游交通民航业' (length=21)
      5 => string '政府机关' (length=12)
      6 => string '餐饮行业' (length=12)
      7 => string '自我创业' (length=12)
      8 => string '其他' (length=6)
  '您对刚就业工资要求是?' => 
    array (size=4)
      0 => string '1000-1500' (length=9)
      1 => string '1500-2000' (length=9)
      2 => string '2000-2500' (length=9)
      3 => string '2500以上 
' (length=13)
  '您所学的专业是?(多选)' => 
    array (size=8)
      0 => string '经管类' (length=9)
      1 => string '机械类' (length=9)
      2 => string '建工类' (length=9)
      3 => string '艺术类' (length=9)
      4 => string '化工、医药类' (length=18)
      5 => string '电子商务、信息、软件类' (length=33)
      6 => string '文法类' (length=9)
      7 => string '教育类' (length=9)

你这是 var_dump 的结果!需要改造后才可用
var_export 输出的是 php 代码格式,直接就可用

array ( 0 => array ( 0 => array ( 'name' => '姓名', 'value' => '123', ), 1 => array ( 'name' => '留言内容', 'value' => '123', ), 2 => array ( 'name' => '联系电话', 'value' => '9896', ), 3 => array ( 'name' => '性别', 'value' => '女', ), 4 => array ( 'name' => '接下来的时间,您是选择就业、创', 'value' => '就业', ), 5 => array ( 'name' => '您的就业择业方向是?(多选)', 'value' => ' 旅游交通民航业, 餐饮行业, 其他 ', ), 6 => array ( 'name' => '您对刚就业工资要求是?', 'value' => '2000-2500', ), 7 => array ( 'name' => '您所学的专业是?(多选)', 'value' => '经管类,建工类,化工、医药类', ), ), 1 => array ( 0 => array ( 'name' => '昵称', 'value' => '哈哈哈', ), 1 => array ( 'name' => '留言内容', 'value' => '嘿嘿', ), 2 => array ( 'name' => '联系电话', 'value' => '111111111121', ), 3 => array ( 'name' => '性别', 'value' => '男', ), 4 => array ( 'name' => '你喜欢常去哪个网站你喜欢常去哪', 'value' => '淘宝淘宝淘宝淘宝淘宝淘宝淘宝淘宝
', ), ), 2 => array ( 0 => array ( 'name' => '昵称', 'value' => '人为财死鸟为食亡', ), 1 => array ( 'name' => '留言内容', 'value' => '什么意思啊', ), 2 => array ( 'name' => '联系电话', 'value' => '13088888888', ), 3 => array ( 'name' => '性别', 'value' => '男', ), ), 3 => array ( 0 => array ( 'name' => '昵称', 'value' => '什么', ), 1 => array ( 'name' => '留言内容', 'value' => '哈哈哈哈哈哈', ), 2 => array ( 'name' => '联系电话', 'value' => '12345597744', ), 3 => array ( 'name' => '性别', 'value' => '女', ), ), )


----------------------------------------------------------


array ( '性别' => array ( 0 => '男', 1 => '女', ), '接下来的时间,您是选择就业、创业?' => array ( 0 => '就业', 1 => '创业', 2 => '升学读书', ), '您的就业择业方向是?(多选)' => array ( 0 => 'IT与通讯业', 1 => '金融、证券、保险业', 2 => '房地产业', 3 => '医药食品业', 4 => '旅游交通民航业', 5 => '政府机关', 6 => '餐饮行业', 7 => '自我创业', 8 => '其他', ), '您对刚就业工资要求是?' => array ( 0 => '1000-1500', 1 => '1500-2000', 2 => '2000-2500', 3 => '2500以上 ', ), '您所学的专业是?(多选)' => array ( 0 => '经管类', 1 => '机械类', 2 => '建工类', 3 => '艺术类', 4 => '化工、医药类', 5 => '电子商务、信息、软件类', 6 => '文法类', 7 => '教育类', ), )


--------
哈哈哈~没注意看,现在这种格式对了吗? 谢谢谢帮忙!!

$d = array ( '性别' => array ( 0 => '男', 1 => '女', ), '接下来的时间,您是选择就业、创业?' => array ( 0 => '就业', 1 => '创业', 2 => '升学读书', ), '您的就业择业方向是?(多选)' => array ( 0 => 'IT与通讯业', 1 => '金融、证券、保险业', 2 => '房地产业', 3 => '医药食品业', 4 => '旅游交通民航业', 5 => '政府机关', 6 => '餐饮行业', 7 => '自我创业', 8 => '其他', ), '您对刚就业工资要求是?' => array ( 0 => '1000-1500', 1 => '1500-2000', 2 => '2000-2500', 3 => '2500以上 ', ), '您所学的专业是?(多选)' => array ( 0 => '经管类', 1 => '机械类', 2 => '建工类', 3 => '艺术类', 4 => '化工、医药类', 5 => '电子商务、信息、软件类', 6 => '文法类', 7 => '教育类', ), );$a = array ( 0 => array ( 0 => array ( 'name' => '姓名', 'value' => '123', ), 1 => array ( 'name' => '留言内容', 'value' => '123', ), 2 => array ( 'name' => '联系电话', 'value' => '9896', ), 3 => array ( 'name' => '性别', 'value' => '女', ), 4 => array ( 'name' => '接下来的时间,您是选择就业、创', 'value' => '就业', ), 5 => array ( 'name' => '您的就业择业方向是?(多选)', 'value' => ' 旅游交通民航业, 餐饮行业, 其他 ', ), 6 => array ( 'name' => '您对刚就业工资要求是?', 'value' => '2000-2500', ), 7 => array ( 'name' => '您所学的专业是?(多选)', 'value' => '经管类,建工类,化工、医药类', ), ), 1 => array ( 0 => array ( 'name' => '昵称', 'value' => '哈哈哈', ), 1 => array ( 'name' => '留言内容', 'value' => '嘿嘿', ), 2 => array ( 'name' => '联系电话', 'value' => '111111111121', ), 3 => array ( 'name' => '性别', 'value' => '男', ), 4 => array ( 'name' => '你喜欢常去哪个网站你喜欢常去哪', 'value' => '淘宝淘宝淘宝淘宝淘宝淘宝淘宝淘宝', ), ), 2 => array ( 0 => array ( 'name' => '昵称', 'value' => '人为财死鸟为食亡', ), 1 => array ( 'name' => '留言内容', 'value' => '什么意思啊', ), 2 => array ( 'name' => '联系电话', 'value' => '13088888888', ), 3 => array ( 'name' => '性别', 'value' => '男', ), ), 3 => array ( 0 => array ( 'name' => '昵称', 'value' => '什么', ), 1 => array ( 'name' => '留言内容', 'value' => '哈哈哈哈哈哈', ), 2 => array ( 'name' => '联系电话', 'value' => '12345597744', ), 3 => array ( 'name' => '性别', 'value' => '女', ), ), );foreach($a as $item) {  foreach($item as $v) if(isset($d[$v['name']])) @$res[$v['name']][$v['value']]++;}print_r($res);
Copier après la connexion
Copier après la connexion
Array(    [性别] => Array        (            [女] => 2            [男] => 2        )    [您的就业择业方向是?(多选)] => Array        (            [ 旅游交通民航业, 餐饮行业, 其他 ] => 1        )    [您对刚就业工资要求是?] => Array        (            [2000-2500] => 1        )    [您所学的专业是?(多选)] => Array        (            [经管类,建工类,化工、医药类] => 1        ))
Copier après la connexion
Copier après la connexion

你好 我能问一下 @$res[$v['name']][$v['value']]++;
这个前面为什么加个@ 吗

$d = array ( '性别' => array ( 0 => '男', 1 => '女', ), '接下来的时间,您是选择就业、创业?' => array ( 0 => '就业', 1 => '创业', 2 => '升学读书', ), '您的就业择业方向是?(多选)' => array ( 0 => 'IT与通讯业', 1 => '金融、证券、保险业', 2 => '房地产业', 3 => '医药食品业', 4 => '旅游交通民航业', 5 => '政府机关', 6 => '餐饮行业', 7 => '自我创业', 8 => '其他', ), '您对刚就业工资要求是?' => array ( 0 => '1000-1500', 1 => '1500-2000', 2 => '2000-2500', 3 => '2500以上 ', ), '您所学的专业是?(多选)' => array ( 0 => '经管类', 1 => '机械类', 2 => '建工类', 3 => '艺术类', 4 => '化工、医药类', 5 => '电子商务、信息、软件类', 6 => '文法类', 7 => '教育类', ), );$a = array ( 0 => array ( 0 => array ( 'name' => '姓名', 'value' => '123', ), 1 => array ( 'name' => '留言内容', 'value' => '123', ), 2 => array ( 'name' => '联系电话', 'value' => '9896', ), 3 => array ( 'name' => '性别', 'value' => '女', ), 4 => array ( 'name' => '接下来的时间,您是选择就业、创', 'value' => '就业', ), 5 => array ( 'name' => '您的就业择业方向是?(多选)', 'value' => ' 旅游交通民航业, 餐饮行业, 其他 ', ), 6 => array ( 'name' => '您对刚就业工资要求是?', 'value' => '2000-2500', ), 7 => array ( 'name' => '您所学的专业是?(多选)', 'value' => '经管类,建工类,化工、医药类', ), ), 1 => array ( 0 => array ( 'name' => '昵称', 'value' => '哈哈哈', ), 1 => array ( 'name' => '留言内容', 'value' => '嘿嘿', ), 2 => array ( 'name' => '联系电话', 'value' => '111111111121', ), 3 => array ( 'name' => '性别', 'value' => '男', ), 4 => array ( 'name' => '你喜欢常去哪个网站你喜欢常去哪', 'value' => '淘宝淘宝淘宝淘宝淘宝淘宝淘宝淘宝', ), ), 2 => array ( 0 => array ( 'name' => '昵称', 'value' => '人为财死鸟为食亡', ), 1 => array ( 'name' => '留言内容', 'value' => '什么意思啊', ), 2 => array ( 'name' => '联系电话', 'value' => '13088888888', ), 3 => array ( 'name' => '性别', 'value' => '男', ), ), 3 => array ( 0 => array ( 'name' => '昵称', 'value' => '什么', ), 1 => array ( 'name' => '留言内容', 'value' => '哈哈哈哈哈哈', ), 2 => array ( 'name' => '联系电话', 'value' => '12345597744', ), 3 => array ( 'name' => '性别', 'value' => '女', ), ), );foreach($a as $item) {  foreach($item as $v) if(isset($d[$v['name']])) @$res[$v['name']][$v['value']]++;}print_r($res);
Copier après la connexion
Copier après la connexion
Array(    [性别] => Array        (            [女] => 2            [男] => 2        )    [您的就业择业方向是?(多选)] => Array        (            [ 旅游交通民航业, 餐饮行业, 其他 ] => 1        )    [您对刚就业工资要求是?] => Array        (            [2000-2500] => 1        )    [您所学的专业是?(多选)] => Array        (            [经管类,建工类,化工、医药类] => 1        ))
Copier après la connexion
Copier après la connexion





还有那个提交的数组,有几个是多选的 ,多选的答案是用逗号分隔开的, 对于那些多选我应该怎么处理比较恰当?

先谢谢你帮我点明了!谢谢!

这就是你的问题了
比如 经管类,建工类,化工、医药类 本来是分属于 您所学的专业是?(多选) 的 经管类、建工类、化工、医药类 子项的,但你把他们联结成了一个串,那就变成一项了。你的再切割成数组,分别统计

foreach($a as $item) {  foreach($item as $v) if(isset($d[$v['name']])) {     foreach(explode(',', [$v['value']]) as $sub)        @$res[$v['name']][$sub]++;  }}
Copier après la connexion
Copier après la connexion

foreach($a as $item) {  foreach($item as $v) if(isset($d[$v['name']])) {     foreach(explode(',', [$v['value']]) as $sub)        @$res[$v['name']][$sub]++;  }}
Copier après la connexion
Copier après la connexion



      @$res[$v['name']][$sub]++;

这个变量前面加@ 主要是目的是什么

屏蔽掉 使用了未赋值的变量 这个错误提示

屏蔽掉 使用了未赋值的变量 这个错误提示



 我发现变成这个格式对应的数组之后,是不是没办法在页面用volist标签输出来。。

那你就自己改造了

那你就自己改造了



好 谢谢啦!

那你就自己改造了



你好,我想再请教一下
就是我遍历完了之后,排序都乱了,怎么才能 按进去的顺序,排出来也是按这个顺序呢 

你可先预置 $res

Déclaration de ce site Web
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

Article chaud

Repo: Comment relancer ses coéquipiers
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
Combien de temps faut-il pour battre Split Fiction?
3 Il y a quelques semaines By DDD
R.E.P.O. Crystals d'énergie expliqués et ce qu'ils font (cristal jaune)
1 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island Adventure: Comment obtenir des graines géantes
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌

Article chaud

Repo: Comment relancer ses coéquipiers
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
Combien de temps faut-il pour battre Split Fiction?
3 Il y a quelques semaines By DDD
R.E.P.O. Crystals d'énergie expliqués et ce qu'ils font (cristal jaune)
1 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island Adventure: Comment obtenir des graines géantes
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌

Tags d'article chaud

Bloc-notes++7.3.1

Bloc-notes++7.3.1

Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise

SublimeText3 version chinoise

Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1

Envoyer Studio 13.0.1

Puissant environnement de développement intégré PHP

Dreamweaver CS6

Dreamweaver CS6

Outils de développement Web visuel

SublimeText3 version Mac

SublimeText3 version Mac

Logiciel d'édition de code au niveau de Dieu (SublimeText3)

11 meilleurs scripts de raccourcissement d'URL PHP (gratuit et premium) 11 meilleurs scripts de raccourcissement d'URL PHP (gratuit et premium) Mar 03, 2025 am 10:49 AM

11 meilleurs scripts de raccourcissement d'URL PHP (gratuit et premium)

Travailler avec les données de session Flash dans Laravel Travailler avec les données de session Flash dans Laravel Mar 12, 2025 pm 05:08 PM

Travailler avec les données de session Flash dans Laravel

Construisez une application React avec un Laravel Back End: Partie 2, React Construisez une application React avec un Laravel Back End: Partie 2, React Mar 04, 2025 am 09:33 AM

Construisez une application React avec un Laravel Back End: Partie 2, React

Misque de réponse HTTP simplifié dans les tests Laravel Misque de réponse HTTP simplifié dans les tests Laravel Mar 12, 2025 pm 05:09 PM

Misque de réponse HTTP simplifié dans les tests Laravel

Curl dans PHP: Comment utiliser l'extension PHP Curl dans les API REST Curl dans PHP: Comment utiliser l'extension PHP Curl dans les API REST Mar 14, 2025 am 11:42 AM

Curl dans PHP: Comment utiliser l'extension PHP Curl dans les API REST

12 meilleurs scripts de chat PHP sur Codecanyon 12 meilleurs scripts de chat PHP sur Codecanyon Mar 13, 2025 pm 12:08 PM

12 meilleurs scripts de chat PHP sur Codecanyon

Notifications à Laravel Notifications à Laravel Mar 04, 2025 am 09:22 AM

Notifications à Laravel

Annonce de l'enquête sur la situation en 2025 PHP Annonce de l'enquête sur la situation en 2025 PHP Mar 03, 2025 pm 04:20 PM

Annonce de l'enquête sur la situation en 2025 PHP

See all articles