2011-06-29 4 views
1

私はイベントサイトを運営しています - Apache/2.28ではPHP/MySQLで動作します。 http://devzone.zend.com/article/13633として表示するHTMLテーブルを取得できます。Twigフレームワークとdatetimeエラー

localhost上のこのサイトについては、wwwに記載されているTwigフレームワークを使用しています。 twig-project。組織

は、コンテンツがローカルのMySQLデータベースから抽出されます。

マイコード:

<html> 
    <head> 
    <style type="text/css"> 
     table { 
     border-collapse: collapse; 
     }   
     tr.heading {  
     font-weight: bolder; 
     }   
     td { 
     border: 1px solid black; 
     padding: 0 0.5em; 
     }  
    </style> 
    </head> 
    <body> 
    <h2>Events</h2> 
    <table> 
     <tr class="heading"> 
     <td>Event time</td> 
     <td>Event name</td> 
     </tr> 
     {% for d in data %} 
     <tr> 
     <td>{{ d.evtime|escape }}</td> 
     <td>{{ d.evname|escape }}</td> 
     </tr> 
     {% endfor %} 
    </table> 
    </body> 
</html> 

// PHPファイルは、しかし、私は得ることができない

<?php 
// include and register Twig auto-loader 
include 'Twig/Autoloader.php'; 
Twig_Autoloader::register(); 

// attempt a connection 
try { 
    $dbh = new PDO('mysql:dbname=world;host=localhost', 'root', 'MYPASS'); 
} catch (PDOException $e) { 
    echo "Error: Could not connect. " . $e->getMessage(); 
} 

// set error mode 
$dbh->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION); 

// attempt some queries 
try { 
    // execute SELECT query 
    // store each row as an object 
    $sql = "SELECT * FROM myeventdb"; 
    $sth = $dbh->query($sql); 
    while ($row = $sth->fetchObject()) { 
    $data[] = $row; 
    } 

    // close connection, clean up 
    unset($dbh); 

    // define template directory location 
    $loader = new Twig_Loader_Filesystem('templates'); 

    // initialize Twig environment 
    $twig = new Twig_Environment($loader); 

    // load template 
    $template = $twig->loadTemplate('countries.tmpl'); 

    // set template variables 
    // render template 
    echo $template->render(array (
    'data' => $data 
)); 

} catch (Exception $e) { 
    die ('ERROR: ' . $e->getMessage()); 
} 
?> 

を下回っています私のイベントでこれと表示する日時: 午後1時30分地理クラス

代わりに 13:30:00と表示されます地理クラス

これはなぜですか、そしてそれを修正する必要がありますか? 私はこれについてかなり新しいです、そして、私はドキュメンテーションを通して見ましたが、それについてのサイトにあまりないです。

乾杯。

答えて

6

したがって、スクリプトは13:30:00と表示されます。これは、データベースから出てくるもので、どこにでも日付を書式設定していないからです。あなたの小枝テンプレートで

、あなたはPHP date function formattingに応じて、お好みに合わせて日付をフォーマットするdate filterを使用することができます。

{{ d.evtime|date('g:ia')|escape }} 

あなたが事前に書式設定をしたいと思った場合は、単にdateの組み合わせを使用し、 strtotime

$formatted_time = date('g:ia',strtotime($unformatted_time));