Numbers and Dates with PHP

Numbers and Dates with PHP

Numbers and Dates with PHP Numbers Numbers can be integer or double. Integer number stores whole numbers. Integer number can have positive or negative sign. By default, is it positive, so the + sign can be omitted when write positive numbers. The maximum value for integer number is – 2147483648 to +2147483647. PHP_INT_MAX constant is used by php to store this value. For example, $max = PHP_INT_MAX; echo "Maximum value for PHP constant is: $max"; Then the output is: Maximum value for PHP constant is: 2147483647; Floating point numbers are also known as floats, doubles or real numbers. Floating point number stores fraction value. To store a number as a floating point number, it must be written with .(decimal point). That means, if a variable assign a value 1 then the data type of a variable is treated as integer. A variable assign a value 1. (one with decimal point) then the data type of a variable is considered as double. Exponential notation can be used in double data type. The exponential notation is consisting of two parts. Mantissa and exponent. This number is written as mantissa e exponent. Mantissa can be integer or floating point number. The exponent must be integer number. The range for exponent is -307 to +308. The exponential notation expand to m * 10e. For example, 3.5e4 expand to 3.5* 104 means 3.5 * 10000 = 35000. In the same way -3.25e-2 expands -3.25*10(-2) = -3.25 * 1/100 = -0.0325. In exponential form the sign of mantissa determine the overall number is positive or negative and the sign of exponent specifies that the number is large or small than 1. If the number is outside of the range of double value, then it is converted by positive or negative infinity. Positive infinity is represented by the constant named INF. Negative infinity is represented by the constant named –INF. You can directly assign infinity to a variable or the result of an operation may be infinity. Generally, most operation where one operand is infinity, the result is infinity. The exception is when a value is divide by zero, it returns zero. In case you divide a value by zero, PHP generates warning. To check whether the variable or expression is infinite, there are two functions available. These functions are: Function Description is_infinite($value) Reruns true if the $value is infinite else false. is_finite($value) Reruns false if the $value is infinite else true. For example: $testinf = is_infinite(10*INF); Page 1 of 12 echo "<br> the value of '10 * INF' is : $testinf"; will display 1 on browser. In-Built useful Number Functions Function Description abs($value) Returns the absolute value of $value ceil($value) Returns the value rounded up to the next highest integer number . Floor Returns the value rounded down to the next lowest integer number. max($v1, $v2 [,$v3, $v4…]) Returns the maximum value among $v1, $v2,$v3,$v4… min($v1, $v2 [,$v3, $v4…]) Returns the minimum value among $v1, $v2,$v3,$v4… pi() Returns the value of PI (Approximate value of PI is 3.14) pow($base,$exp) Returns the value of $base raise to $exp. round($value [, $precision]) Returns the rounded value of $value to the decimal point specified by $precision. If $precision is omitted, this function consider $precision default value 0. If $precision is negative, this function rounds to a whole number. For example, in case $precision is -1,then it rounds to $value to the nearest 10. If $precision is -2 then it rounds to $value to the nearest 100. sqrt($value) Returns the square root of $value. mt_rand() This functions return a random number using Mersenne Twister function. Type Casting: Type casting is used to convert one data type to another type. To type cast a value, write the data type in parentheses before the value. Below are few examples of type casting. // Type casting $value = 31.8; $intcast = (int)$value; echo "<br> The original $value after casting to integer becomes: $intcast "; //with string Page 2 of 12 $value = "31.8 Kilometers"; // strings after the number is ignored $strint = (int)$value; echo "<br> The original '$value' after casting to integer becomes: $strint "; //, $value = "31,000 Kilometers"; $strint = (int)$value; echo "<br> The original '$value' after casting to integer becomes: $strint "; // string and number_format $value = "Kilometres 31,000"; // strings which not start with number is converted to 0 $strint = (int)$value; echo "<br> The original '$value' after casting to integer becomes: $strint "; //only string $value = "Kilometres"; $strint = (int)$value; echo "<br> The original '$value' after casting to integer becomes: $strint "; //out of range value $value = '10000000000'; $strint = (int)$value; echo "<br> The original '$value' after casting to integer becomes: $strint "; The output is: The original 31.8 after casting to integer becomes: 31 The original '31.8 Kilometers' after casting to integer becomes: 31 The original '31,000 Kilometers' after casting to integer becomes: 31 The original 'Kilometres 31,000' after casting to integer becomes: 0 The original 'Kilometres' after casting to integer becomes: 0 The original '10000000000' after casting to integer becomes: 2147483647 Sprintf Page 3 of 12 The sprint function is used to format strings and numbers. The general syntax of sprintf function is: sprintf(format, $val1 [,$val2 ….]) The format parameter can take any one value of for formatting $val. The format parameter can take any one of the following data type s : string d : integer f: double/decimal value e: exponential notation c: convert integer value corresponding to equivalent ASCII character. The format-code must start with % symbol end ends with data type. Few examples for sprintf function is shown below. //sprintf examples $msg = sprintf("The book on %s has %d pages","PHP", 543); echo "<br> $msg"; $s1 = sprintf("%c",65); echo "<br> The ASCII character for value 65 is : $s1"; $s2 = sprintf("%06d",42); echo "<br> The value 42 padded with 0 for length 0f 6 is: $s2"; $date = sprintf("%02d-%02d-%04d", 3,5,2015); echo "<br> Print the date in DD-MM-YYYY format : $date"; $s4 = sprintf("%09.2f", 123.4567890); Page 4 of 12 echo "<br> The value is: $s4"; The output of the above code is: The book on PHP has 543 pages The ASCII character for value 65 is : A The value 42 paddedwith 0 for length 0f 6 is: 000042 Print the date in DD-MM-YYYY format : 03-05-2015 The value is: 000123.46 Date: PHP is used timestamp to display date and time. Timestamp stores an integer value, which stores the numbers of second since midnight on January 1, 1970 GMT (Greenwich Mean Time). This point of time is known as the Unix Epoch. Timestamp stored as a 32-bit signed integer number by most systems in the world. Hence these system timestamp can range from December 13, 1901 to January 19, 2038. When the system uses timestamps, reaches its upper limit January 19, 2038 its rolls over to the lower limit in 1901. When this may happens, it may create many problems. This problem is known as the year 2038 problem. This problem is similar to Y2K problem, so year 2038 problem is also known as Y2K38 problem. One way to solve the Y2K38 problem is to use DateTime objects. The DateTime object is explain later on. To create and format timestamp date( ) is used. The general syntax for date( ) function is: Date($format [, $timestamp]) Where $format represents various formatting option for date and $ts is a timestamp. The date function returned the formatted timestamp. The format is specified in $format. By default the time stamp is current date and time. The $timestamp can be specified for any date or time. For example: $d = date('j-n-Y'); echo "<br>Today is $d"; display Today is 31-5-2015. There are many formatting options available. Following table shows few formatting options. Page 5 of 12 Format Description j Day of month without leading zero. d Day of month with leading zero. D Day of week in three letters (i.e.: Mon). l Day of week full-name (i.e.: Monday) n Month number without leading zero m Month number with leading zero M Month name in three letters. S Ordinal Suffix of a day F Full Month Name. y Year in two digits. Y Year in four digits. L Leap year or not. For leap year it is return 1 otherwise 0. h Hours in 24 hour format without leading zero. g Hours in 12 hour format without leading zero. H Hours in 24 hour format with leading zero. G Hours in 12 hour format with leading zero i Minutes with leading zero s Seconds with leading zero A AM/PM in uppercase a am/pm in lowercase U Seconds since unix epoch For example, $d = date('j-n-Y \a\t H:i A '); echo "<br>Today is $d"; will display Today is 31-5-2015 at 08:57 AM Useful functions for working with Timestamps Function Description time() Returns current date time as timestamp mktime([$h [,$m [,$s [,$M [,$D [,$Y]]]]]]) Returns timestamp based on the parameters passed. If any parameter is skipped, then the value of current date and time is set. checkdate($M,$D,$Y) Returns true if the $M (month), $D (date) and $Y (year) provide valid date. getdate([$ts]) Returns an array having parts of time Page 6 of 12 stamp. If $ts is omitted, it uses current date and time. Following code shows use of timestamp functions: $ts = time(); echo "<br>The value of current time stamp is : $ts"; $mts = mktime(10, 10, 00,13, 4, 2012 ); echo "<br>The new time stamp has value: $mts"; $chkdt = checkdate(11,30,2015); echo "<br> 30 Novemebr 2015 by checkdate returns: $chkdt <br>"; Then the output will be: The value of current time stamp is : 1433058159 The new time stamp has value: 1357290600 30 November 2015 by checkdate returns: 1 You can find many timestamp functions at PHP manual on the web.

View Full Text

Details

  • File Type
    pdf
  • Upload Time
    -
  • Content Languages
    English
  • Upload User
    Anonymous/Not logged-in
  • File Pages
    12 Page
  • File Size
    -

Download

Channel Download Status
Express Download Enable

Copyright

We respect the copyrights and intellectual property rights of all users. All uploaded documents are either original works of the uploader or authorized works of the rightful owners.

  • Not to be reproduced or distributed without explicit permission.
  • Not used for commercial purposes outside of approved use cases.
  • Not used to infringe on the rights of the original creators.
  • If you believe any content infringes your copyright, please contact us immediately.

Support

For help with questions, suggestions, or problems, please contact us