Tips

PHP練習問題 問25

PHP練習問題 問25

もう少しフロー制御あたりの問題をだしたいところなのですが、日付の問題に行こうと思います。
WEBシステムでざっくりと扱うデータ型は、文字列、数字、日付となります。
真偽値とかオブジェクトとか色々あると思うのですが、文字列から数字又は文字列から日付に変換というのが基本的な考えで、高度になるとそれをオブジェクトへ割り当てます。

文字列からオブジェクトへ変換することを解析(パース)といい、オブジェクトから文字列に変換することを書式化(フォーマット)と言います。
画面から送られてくる文字列を解析し、オブジェクトを生成。その後の処理(エラーチェックやDBへの登録)を行い、画面(HTML)を出力する際に書式化(フォーマット)します。

ここで、面倒なのが数字と日付です。初心者ははまりやすいと思います。
まずは書式化の問題です。

その前に、XAMPPで実行される場合に、php.iniの設定が「Europe/Berlin」になっている場合があるので確認してみましょう。
XAMPPのインストールフォルダのphpの下にphp.iniがあります。テキストエディタで開き、「date.timezone」を検索。

date.timezone=Europe/Berlin

このように設定されている場合は、以下のように変更します。

date.timezone=Asia/Tokyo

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

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

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


phpedu25.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
<?php
    $fms    = [
        'Y-m-d H:i:s', 'y-m-D h:i:S', 'y-M-d h:I:s'
    ];
?>
<!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">
 
        <!--[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問題25</h1>
            </div>
            <div class="jumbotron">
            <h3>
            <?php
                foreach($fms as $k => $f){
                    echo $k.' '.date($f).'<br>';
                }
            ?>
            </h3>
            </div>
        </div>
        <script src="https://code.jquery.com/jquery-1.11.3.min.js"></script>
    </body>
</html>


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

問題:年(4桁)、月、日、時間(24表記)、分、秒と正しく表示されるのはどれでしょうか?(複数選択可)

  1. Y-m-d H:i:s
  2. y-m-D h:i:S
  3. y-M-d h:I:s
  4. 全て正しく表示される。
  5. 特に何も出力されない。
  6. エラーが出力される。

正解:1.Y-m-d H:i:s

Yは、西暦を4桁表記。小文字は2桁表記になります。
mは、月2桁表記。大文字は文字列表記になります。
dは、日2桁表記。大文字は曜日の文字表記になります。
Hは、時間24時間表記。小文字は12時間表記になります。
iは、分2桁表記。
sは、秒2桁表記。

書式に関してはphpのdate関数のformatを参照してください。

新連載はじまりました!新PHP基礎 連載リンク

PHP基礎 連載

Recent News

Recent Tips

Tag Search