配列と繰り返し処理の問題です。
少し実践に近づけて、表形式(2次元配列)を扱った問題です。
前回と同じ配列を利用します。
PHPをWindowsで実行したいのであれば、XAMPP(ザンプ)をインストールすると、自分のPCでも簡単に動作させることが出来ます。
インストール方法は、以下のサイトから。
WINDOWS XAMPP にて LARAVEL をインストール (XAMPP V1.8.3インストール)
phpedu24.php
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 | <?php $usr = [ [ '名前' => '山田' , '性別' => '男' , '数学' => 78, '国語' => 47, '英語' => 92], [ '名前' => '田中' , '性別' => '女' , '数学' => 12, '国語' => 88, '英語' => 67], [ '名前' => '高橋' , '性別' => '男' , '数学' => 56, '国語' => 34, '英語' => 77], [ '名前' => '橋本' , '性別' => '女' , '数学' => 97, '国語' => 55, '英語' => 45] ]; ?> <!DOCTYPE html> <html> <head> <meta charset= "utf-8" > <meta http-equiv= "X-UA-Compatible" content= "IE=edge" > <meta name= "viewport" content= "width=device-width, initial-scale=1.0" > <title>tech.pjin.jp HTML5 Template</title> <link rel= "stylesheet" href= "https://maxcdn.bootstrapcdn.com/bootstrap/3.3.5/css/bootstrap.min.css" > <link rel= "stylesheet" href= "https://maxcdn.bootstrapcdn.com/font-awesome/4.4.0/css/font-awesome.min.css" > <!--[ if lt IE 9]> <![ endif ]--> </head> <body> <div class = "container" > <div class = "page-header" > <h1><i class = "fa fa-check-square" ></i> PHP問題24</h1> </div> <div class = "jumbotron" > <h3> <?php $sum = 0; foreach ( $usr as $k => $u ){ if ( $u [ '性別' ] == '女' ){ $sum += $u [ '国語' ]; } } print $sum ; ?> </h3> </div> </div> </body> </html> |
※CSSには、Bootstrap、Font-Awesomeを利用しています。
※Javascriptには、jQuery1.11.3を利用しています。
問題:このPHPをブラウザで見た結果(実行結果)を答えなさい(複数選択可)
- 「100」と表示される。
- 「227」と表示される。
- 「47」と表示される。
- 「552」と表示される。
- 「143」と表示される。
- 特に何も出力されない。
- エラーが出力される。
正解:5.「143」と表示される。
表形式のデータを操作しています。
名前 | 性別 | 数学 | 国語 | 英語 |
---|---|---|---|---|
山田 | 男 | 78 | 47 | 92 |
田中 | 女 | 12 | 88 | 67 |
高橋 | 男 | 56 | 34 | 77 |
橋本 | 女 | 97 | 55 | 45 |
上記のような連想配列になっています。
通常の配列は数字でアクセスしますが、連想配列は文字列でアクセスします。
ですので、$usr
の配列の1要素である$u
は、キーに名前、性別、数学、国語、英語を持っています。
数学の点数にアクセスする場合は、$u['数学']
としてアクセスできます。
さて今回は、2つの属性にアクセスしています。
性別と国語です。
性別が女で、国語の数字を累計しています。
結果、88+55で143と出力されます。