آموزش PHP- جلسه هجدهم: کار با تاریخ و ساعت و تاریخ هجری شمسی

در این جلسه از سری آموزشی پی‌اچ‌پی قصد داریم در مورد تاریخ و ساعت صحبت کنیم. مطمئنا مواقع زیادی پیش می‌آید که نیاز به درج ساعت و تاریخ در پی‌اچ‌پی خواهید داشت و یادگیری توابع مرتبط و نحوه استفاده از آن‌ها بسیار مهم است. در ادامه با ما همراه باشید.

تاریخ همیشه بخش مهمی از زندگی روزمره را تشکیل می‌دهد و باعث می‌شود بتوانیم به انجام همه کارهای خود برسیم. توابع مربوط به ساعت و تاریخ در پی‌اچ‌پی بسیار مهم هستند. نیاز به نمایش تاریخ و ساعت هم در مواقع ثبت اطلاعات و هم در مواقع نمایش دادن اطلاعات وجود دارد. پی‌اچ‌پی ابزارهای بسیار قدرتمندی را به منظور استفاده از تاریخ و ساعت در اختیار توسعه‌دهندگان می‌گذارد.

دریافت زمان با ()time

تابع ()time تمام اطلاعات لازم برای لحظه حاضر از تاریخ و ساعت را در اختیار شما قرار خواهد داد. این تابع نیاز به هیچ آرگومان ورودی ندارد اما یک رشته متنی را به خروجی می‌دهد.

رشته متنی که از این تابع برگردانده می‌شود تعداد ثانیه‌های سپری شده از نیمه‌شب ۱ ژانویه ۱۹۷۰ را به وقت GMT نشان می‌دهد. زمان حاضر به شکل UNIX نمایش می‌یابد که این یعنی تعداد ثانیه‌های گذشته شده از یک زمان مرجع.

برای نمایش خروجی این تابع ابتدا نرم‌افزار Xampp را اجرا کرده و سرورهای آپاچی و MySQL را فعال کنید. حال در پوشه htdocs یک پوشه به اسم time بسازید. در این پوشه فایلی به نام test.php ساخته و کد زیر را در آن قرار دهید.

<?php

echo time();

?>

اجرای کد فوق از طریق آدرس http://127.0.0.1/time/index.php باعث ایجاد نتیجه‌ای مثل عدد ۱۴۶۶۶۶۹۴۱۶ خواهد شد. 

فهمیدن این عدد قطعا کار آسانی نیست. اما PHP ابزارهای بسیار خوبی را برای تبدیل این عدد به فرمت‌های قابل فهم و معمول تاریخ و زمان ارائه می‌دهد.

تابع ()getdate

تابع ()getdate می‌تواند timstamp (خروجی‌ که از تابع ()time به دست می‌آید) را به طور اختیاری به عنوان ورودی دریافت کند. خروجی این تابع یک آرایه از اطلاعات مربوط به تاریخ است. اگر شما ورودی این تابع را تعیین نکنید از میزان خروجی کنونی ()time استفاده می‌کند.

در جدول زیر می‌توانید لیست المان‌های آرایه‌ای که از تابع getdate به‌دست می‌آید را مشاهده کنید.

شمارهکلید و توضیحمثال
۱seconds: تعداد ثانیه‌های گذشته از دقیقه کنونی (۰-۵۹)۲۰
۲minutes: تعداد دقایق گذشته از ساعت کنونی (۰ – ۵۹)۲۹
۳hours: تعداد ساعت‌های گذشته از روز کنونی (۰ – ۲۳)۲۲
۴mday: روز ماه کنونی (۱ – ۳۱)۱۱
۵wday: روز هفته کنونی (۰ – ۶)۴
۶mon: ماه سال کنونی (۱ – ۱۲)۷
۷year: سال (۴ رقمی)۱۹۹۷
۸yday: روز کنونی در سال جاری ( ۰ – ۳۶۵ )۱۹
۹weekday: روز جاری در هفته کنونیThursday
۱۰month: ماه جاری در سال کنونیJanuary
۱۱۰: Timestamp – تایم‌استامپ۹۴۸۳۷۰۰۴۸

حال شما می‌توانید با استفاده از داده‌های فوق کنترل کاملی را بر روی تاریخ و ساعت داشته باشید. شما می‌توانید براساس فرمت موردنیاز خود از داده‌های بالا استفاده کنید.

به مثال زیر دقت کنید:

<?php
$date_array = getdate();

foreach ( $date_array as $key => $val ){
print “$key = $val<br />”;
}

$formated_date = “Today’s date: “;
$formated_date .= $date_array[‘mday’] . “/”;
$formated_date .= $date_array[‘mon’] . “/”;
$formated_date .= $date_array[‘year’];

print $formated_date;
?>

نتیجه اجرای کد فوق چیزی شبیه به زیر است:

seconds = 18

minutes = 10

hours = 8

mday = 25

wday = 4

mon = 6

year = 2016

yday = 174

weekday = Thursday

month = June

۰ = ۱۴۶۶۶۶۹۴۱۸

Today’s date: 25/6/2016

تبدیل تایم‌استامپ با تابع ()date

تابع ()date شکل فرمت‌بندی شده‌ای از تاریخ و زمان را نشان می‌دهد. شما می‌توانید تعداد بسیار زیادی فرمت بر حسب خلاقیت یا نیاز خود با این تابع به‌دست آورید. کد استاندارد این تابع به شکل زیر است:

date(format,timestamp)

تابع ()date نیز می‌تواند تایم‌استامپ (timestamp) موردنظرتان را به صورت اختیاری به عنوان ورودی دریافت کند و اگر این ورودی تعیین نشود، از زمان کنونی استفاده خواهد شد. در جدول زیر لیستی از فرمت‌هایی که می‌توانید با این تابع استفاده کنید آورده شده است.

شمارهفرمت و توضیحمثال
۱a: واژه ‘am’ یا ‘pm’ با حروف کوچکpm
۲ A: واژه ‘AM’ یا ‘PM’ با حروف بزرگPM
۳d: روز جاری در ماه کنونی۲۰
۴D: روز هفته جاری (سه کاراکتر)Thu
۵F: نام ماه جاریJanuary
۶h: ساعت (فرمت ۱۲ ساعته – اعداد تک رقمی با یک صفر پیش از عدد)۱۲
۷H: ساعت (فرمت ۲۴ ساعته – اعداد تک رقمی با یک صفر پیش از عدد)۲۲
۸g: ساعت (فرمت ۱۲ ساعته  – اعداد تک رقمی بدون یک صفر پیش از عدد)۱۲
۹G: ساعت (فرمت ۲۴ ساعته – اعداد تک رقمی بدون یک صفر پیش از عدد)۲۲
۱۰i: دقیقه ( ۰ – ۵۹ )۲۳
۱۱j: روز ماه جاری (اعداد تک رقمی بدون یک صفر پیش از عدد)۲۰
۱۲l (حرف کوچک ‘L’): روز هفتهThursday
۱۳L: کبیسه بودن سال (‘۱’ بله, ‘۰’ خیر)۱
۱۴m: ماه جاری سال کنونی (عدد – اعداد تک رقمی با یک صفر پیش از عدد)۱
۱۵M: ماه جاری سال کنونی (سه کاراکتر)Jan
۱۶r: فرمت RFC 2822Thu, 21 Dec 2000 16:01:07 +0200
۱۷n: ماه جاری سال کنونی (عدد – اعداد تک رقمی بدون یک صفر پیش از عدد)۲
۱۸s: ثانیه‌های گذشته شده از دقیقه جاری۲۰
۱۹U: تایم‌استامپ۹۴۸۳۷۲۴۴۴
۲۰y: سال (دو رقم)۰۶
۲۱Y: سال (چهار رقم)۲۰۰۶
۲۲z: روز کنونی سال جاری (۰ – ۳۶۵)۲۰۶
۲۳Z: افست ثانیه‌ها از GMT

به عنوان مثال کد زیر را در یک فایل وارد کرده و آن را اجرا کنید:

<?php
print date(“m/d/y G.i:s<br>”, time());
print “Today is “;
print date(“j of F Y, \a\\t g.i a”, time());
?>

خروجی کد بالا به شکل زیر خواهد بود:

۰۶/۲۵/۱۶ ۸٫۱۰:۱۷<bthu, 25=”” jun=”” 2016=”” 08:10:17=”” +0000=””>Today is 25 2016f June 2016, at 8.10 am

اما تمام آنچه گفته شد فقط برای تاریخ‌های میلادی به‌کار می‌روند و برای استفاده از تاریخ شمسی باید از یک کلاس خارجی استفاده کنید. این‌که کلاس خارجی چیست فعلا نباید مدنظر شما باشد. اگر به خاطر داشته باشید روش include کردن فایل‌ها را در جلسات گذشته مرور کردیم. شما باید فایل مربوط به کلاس تاریخ شمسی را به فایل موردنظر خود که قصد استفاده از تاریخ شمسی را در آن دارید inlcude کرده و سپس به جای تابع ()date از ()jdate استفاده کنید. تمامی عملکرد‌های تابع ()jdate دقیقا شبیه به تابع ()date است. ابتدا فایل jdf.php را از این لینک دانلود کنید و سپس فایل jdf.php را در کنار فایل موردنظر خود به عنوان مثال در پوشه time که در پوشه htdocs ساخته بودید قرار دهید. سپس در فایلی که قصد استفاده از تاریخ هجری شمسی را در آن دارید فایل jdf.php را include کنید. به‌عنوان مثال به کد زیر دقت کنید:

<?php

include (“jdf.php”);

print jdate(“j of F Y, \a\\t g.i a”, time());
?>

در کد بالا ما فقط date را به jdate تغییر دادیم. در این‌صورت نتیجه اجرای کد فوق چیزی شبیه به زیر خواهد بود:

۳ ۱۳۹۵ تابستان تیر ۱۳۹۵, at ۱.۵۴ ب.ظ

همان‌طور که می‌بینید فرمتی که برای نمایش تاریخ میلادی بود را بدون تغییر برای تاریخ هجری شمسی استفاده کردیم که زیاد جالب نیست. می‌توان از فرمتی مثل زیر استفاده کرد. کد بالا را به شکل زیر تغییر دهید:

<?php

include (“jdf.php”);

print jdate(“j F Y – h:s”, time());

?>

نتیجه کد بالا به شکل زیر خواهد بود:

۳ تیر ۱۳۹۵- ۰۱:۲۸

قطعا فرمت بالا نسبت به فرمت قبلی برای کاربران فارسی زبان گویاتر است. لازم به ذکر است که در فایلی که در بالا لینک دانلود آن را قرار دادیم، راهنمای کامل تابع jdate نیز وجود دارد که از سایت رسمی سازنده آن منتشر شده و برای یادگیری عمیق‌تر این توابع jdf.php می‌توانید به راهنمای موجود در فایل دانلود شده یا وب‌سایت http://jdf.scr.ir مراجعه کنید.

در جلسات بعدی با مباحث پیشرفته‌تر و جزئی‌تر دیگری در پی‌اچ‌پی آشنا خواهید شد. نظرات و سوالات خود را در مورد مباحث این جلسه مثل همیشه در بخش دیدگاه‌ها با زومیت و سایر کاربران به اشتراک بگذارید.

منبع: زومیت

دیدگاهتان را بنویسید

نشانی ایمیل شما منتشر نخواهد شد. بخش‌های موردنیاز علامت‌گذاری شده‌اند *