PHP練習問題

PHP練習問題 問28


PHP練習問題 問28

前回に引き続き、日付に関する問題です。
今回は繰り返し処理を利用して日付の加算を行うサンプルです。
少し意地悪な問題ですが、しっかりとソースをみて実行結果を想像してみましょう。

PHPをWindowsで実行したいのであれば、XAMPP(ザンプ)をインストールすると、自分のPCでも簡単に動作させることが出来ます。

インストール方法は、以下のサイトから。

WINDOWS XAMPP にて LARAVEL をインストール (XAMPP V1.8.3インストール)


phpedu28.php

<?php
	$day	= strtotime('2016-01-01');
?>
<!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]>
			<script src="https://cdnjs.cloudflare.com/ajax/libs/html5shiv/3.7.3/html5shiv.min.js"></script>
			<script src="https://cdnjs.cloudflare.com/ajax/libs/respond.js/1.4.2/respond.min.js"></script>
		<![endif]-->
	</head>
	<body>
		<div class="container">
			<div class="page-header">
				<h1><i class="fa fa-check-square"></i> PHP問題28</h1>
			</div>
			<div class="jumbotron">
			<h3>
			<?php
				for($i=0;$i<7;$i++){
					$day	= strtotime('+'.$i.' day', $day);
				}
				echo date('Y-m-d', $day);
			?>
			</h3>
			</div>
		</div>
		<script src="https://code.jquery.com/jquery-1.11.3.min.js"></script>
		<script src="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.5/js/bootstrap.min.js"></script>
	</body>
</html>


※CSSには、Bootstrap、Font-Awesomeを利用しています。
※Javascriptには、jQuery1.11.3を利用しています。

問題:このPHPをブラウザで見た結果(実行結果)を答えなさい(複数選択可)

  1. 2016-01-06
  2. 2016-01-07
  3. 2016-01-08
  4. 2016-01-21
  5. 2016-01-22
  6. 2016-01-23
  7. 特に何も出力されない。
  8. エラーが出力される。

正解:5.2016-01-22

for文を使った日付の加算を行いました。
ここで注目するべきは、1日加算ではないという点です。
よく初心者で間違えるのはループの状態変数(ここでは$i)ですが、これを間違えて足してしまうということを行っています。

strtotime('+1 day', $day)とした場合は、ループの回数分日付を加算するのですが、
問題では、strtotime('+'.$i.' day', $day)としており、ループのカウンターが増えれば加算する日付も増えてしまいます。
あまりこういうコードはないので、ちゃんと定数又はリテラルで何日としていするのが良いと思います。

  • このエントリーをはてなブックマークに追加

PAGE TOP