| 
									
										
										
										
											2010-08-26 19:14:53 +00:00
										 |  |  | <?php | 
					
						
							|  |  |  | /** | 
					
						
							|  |  |  |  * PHPExcel | 
					
						
							|  |  |  |  * | 
					
						
							| 
									
										
										
										
											2013-05-14 11:20:28 +00:00
										 |  |  |  * Copyright (c) 2006 - 2013 PHPExcel | 
					
						
							| 
									
										
										
										
											2010-08-26 19:14:53 +00:00
										 |  |  |  * | 
					
						
							|  |  |  |  * This library is free software; you can redistribute it and/or | 
					
						
							|  |  |  |  * modify it under the terms of the GNU Lesser General Public | 
					
						
							|  |  |  |  * License as published by the Free Software Foundation; either | 
					
						
							|  |  |  |  * version 2.1 of the License, or (at your option) any later version. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * This library is distributed in the hope that it will be useful, | 
					
						
							|  |  |  |  * but WITHOUT ANY WARRANTY; without even the implied warranty of | 
					
						
							|  |  |  |  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU | 
					
						
							|  |  |  |  * Lesser General Public License for more details. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * You should have received a copy of the GNU Lesser General Public | 
					
						
							|  |  |  |  * License along with this library; if not, write to the Free Software | 
					
						
							|  |  |  |  * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * @category	PHPExcel | 
					
						
							|  |  |  |  * @package		PHPExcel_Calculation | 
					
						
							| 
									
										
										
										
											2013-05-14 11:20:28 +00:00
										 |  |  |  * @copyright	Copyright (c) 2006 - 2013 PHPExcel (http://www.codeplex.com/PHPExcel) | 
					
						
							| 
									
										
										
										
											2010-08-26 19:14:53 +00:00
										 |  |  |  * @license		http://www.gnu.org/licenses/old-licenses/lgpl-2.1.txt	LGPL | 
					
						
							|  |  |  |  * @version		##VERSION##, ##DATE##
 | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /** PHPExcel root directory */ | 
					
						
							|  |  |  | if (!defined('PHPEXCEL_ROOT')) { | 
					
						
							|  |  |  | 	/** | 
					
						
							|  |  |  | 	 * @ignore | 
					
						
							|  |  |  | 	 */ | 
					
						
							|  |  |  | 	define('PHPEXCEL_ROOT', dirname(__FILE__) . '/../../'); | 
					
						
							|  |  |  | 	require(PHPEXCEL_ROOT . 'PHPExcel/Autoloader.php'); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /** MAX_VALUE */ | 
					
						
							|  |  |  | define('MAX_VALUE', 1.2e308); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /** 2 / PI */ | 
					
						
							|  |  |  | define('M_2DIVPI', 0.63661977236758134307553505349006); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /** MAX_ITERATIONS */ | 
					
						
							|  |  |  | define('MAX_ITERATIONS', 256); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /** PRECISION */ | 
					
						
							|  |  |  | define('PRECISION', 8.88E-016); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /** | 
					
						
							|  |  |  |  * PHPExcel_Calculation_Functions | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * @category	PHPExcel | 
					
						
							|  |  |  |  * @package		PHPExcel_Calculation | 
					
						
							| 
									
										
										
										
											2013-05-14 11:20:28 +00:00
										 |  |  |  * @copyright	Copyright (c) 2006 - 2013 PHPExcel (http://www.codeplex.com/PHPExcel) | 
					
						
							| 
									
										
										
										
											2010-08-26 19:14:53 +00:00
										 |  |  |  */ | 
					
						
							|  |  |  | class PHPExcel_Calculation_Functions { | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/** constants */ | 
					
						
							|  |  |  | 	const COMPATIBILITY_EXCEL		= 'Excel'; | 
					
						
							|  |  |  | 	const COMPATIBILITY_GNUMERIC	= 'Gnumeric'; | 
					
						
							|  |  |  | 	const COMPATIBILITY_OPENOFFICE	= 'OpenOfficeCalc'; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	const RETURNDATE_PHP_NUMERIC	= 'P'; | 
					
						
							|  |  |  | 	const RETURNDATE_PHP_OBJECT		= 'O'; | 
					
						
							|  |  |  | 	const RETURNDATE_EXCEL			= 'E'; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/** | 
					
						
							| 
									
										
										
										
											2012-03-11 17:58:38 +00:00
										 |  |  | 	 * Compatibility mode to use for error checking and responses | 
					
						
							| 
									
										
										
										
											2010-08-26 19:14:53 +00:00
										 |  |  | 	 * | 
					
						
							| 
									
										
										
										
											2012-03-11 17:58:38 +00:00
										 |  |  | 	 * @access	private | 
					
						
							|  |  |  | 	 * @var string | 
					
						
							| 
									
										
										
										
											2010-08-26 19:14:53 +00:00
										 |  |  | 	 */ | 
					
						
							| 
									
										
										
										
											2010-12-02 17:56:33 +00:00
										 |  |  | 	protected static $compatibilityMode	= self::COMPATIBILITY_EXCEL; | 
					
						
							| 
									
										
										
										
											2010-08-26 19:14:53 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	/** | 
					
						
							| 
									
										
										
										
											2012-03-11 17:58:38 +00:00
										 |  |  | 	 * Data Type to use when returning date values | 
					
						
							| 
									
										
										
										
											2010-08-26 19:14:53 +00:00
										 |  |  | 	 * | 
					
						
							| 
									
										
										
										
											2012-03-11 17:58:38 +00:00
										 |  |  | 	 * @access	private | 
					
						
							|  |  |  | 	 * @var string | 
					
						
							| 
									
										
										
										
											2010-08-26 19:14:53 +00:00
										 |  |  | 	 */ | 
					
						
							| 
									
										
										
										
											2010-12-02 17:56:33 +00:00
										 |  |  | 	protected static $ReturnDateType	= self::RETURNDATE_EXCEL; | 
					
						
							| 
									
										
										
										
											2010-08-26 19:14:53 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	/** | 
					
						
							| 
									
										
										
										
											2012-03-11 17:58:38 +00:00
										 |  |  | 	 * List of error codes | 
					
						
							| 
									
										
										
										
											2010-08-26 19:14:53 +00:00
										 |  |  | 	 * | 
					
						
							| 
									
										
										
										
											2012-03-11 17:58:38 +00:00
										 |  |  | 	 * @access	private | 
					
						
							|  |  |  | 	 * @var array | 
					
						
							| 
									
										
										
										
											2010-08-26 19:14:53 +00:00
										 |  |  | 	 */ | 
					
						
							| 
									
										
										
										
											2010-12-02 17:56:33 +00:00
										 |  |  | 	protected static $_errorCodes	= array( 'null'				=> '#NULL!', | 
					
						
							|  |  |  | 											 'divisionbyzero'	=> '#DIV/0!', | 
					
						
							|  |  |  | 											 'value'			=> '#VALUE!', | 
					
						
							|  |  |  | 											 'reference'		=> '#REF!', | 
					
						
							|  |  |  | 											 'name'				=> '#NAME?', | 
					
						
							|  |  |  | 											 'num'				=> '#NUM!', | 
					
						
							|  |  |  | 											 'na'				=> '#N/A', | 
					
						
							|  |  |  | 											 'gettingdata'		=> '#GETTING_DATA' | 
					
						
							|  |  |  | 										   ); | 
					
						
							| 
									
										
										
										
											2010-08-26 19:14:53 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/** | 
					
						
							| 
									
										
										
										
											2012-03-11 17:58:38 +00:00
										 |  |  | 	 * Set the Compatibility Mode | 
					
						
							| 
									
										
										
										
											2010-08-26 19:14:53 +00:00
										 |  |  | 	 * | 
					
						
							| 
									
										
										
										
											2012-03-11 17:58:38 +00:00
										 |  |  | 	 * @access	public | 
					
						
							|  |  |  | 	 * @category Function Configuration | 
					
						
							|  |  |  | 	 * @param	 string		$compatibilityMode		Compatibility Mode | 
					
						
							| 
									
										
										
										
											2010-08-26 19:14:53 +00:00
										 |  |  | 	 *												Permitted values are: | 
					
						
							|  |  |  | 	 *													PHPExcel_Calculation_Functions::COMPATIBILITY_EXCEL			'Excel' | 
					
						
							|  |  |  | 	 *													PHPExcel_Calculation_Functions::COMPATIBILITY_GNUMERIC		'Gnumeric' | 
					
						
							|  |  |  | 	 *													PHPExcel_Calculation_Functions::COMPATIBILITY_OPENOFFICE	'OpenOfficeCalc' | 
					
						
							| 
									
										
										
										
											2012-03-11 17:58:38 +00:00
										 |  |  | 	 * @return	 boolean	(Success or Failure) | 
					
						
							| 
									
										
										
										
											2010-08-26 19:14:53 +00:00
										 |  |  | 	 */ | 
					
						
							|  |  |  | 	public static function setCompatibilityMode($compatibilityMode) { | 
					
						
							|  |  |  | 		if (($compatibilityMode == self::COMPATIBILITY_EXCEL) || | 
					
						
							|  |  |  | 			($compatibilityMode == self::COMPATIBILITY_GNUMERIC) || | 
					
						
							|  |  |  | 			($compatibilityMode == self::COMPATIBILITY_OPENOFFICE)) { | 
					
						
							|  |  |  | 			self::$compatibilityMode = $compatibilityMode; | 
					
						
							|  |  |  | 			return True; | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 		return False; | 
					
						
							|  |  |  | 	}	//	function setCompatibilityMode()
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/** | 
					
						
							| 
									
										
										
										
											2012-03-11 17:58:38 +00:00
										 |  |  | 	 * Return the current Compatibility Mode | 
					
						
							| 
									
										
										
										
											2010-08-26 19:14:53 +00:00
										 |  |  | 	 * | 
					
						
							| 
									
										
										
										
											2012-03-11 17:58:38 +00:00
										 |  |  | 	 * @access	public | 
					
						
							|  |  |  | 	 * @category Function Configuration | 
					
						
							|  |  |  | 	 * @return	 string		Compatibility Mode | 
					
						
							| 
									
										
										
										
											2010-08-26 19:14:53 +00:00
										 |  |  | 	 *							Possible Return values are: | 
					
						
							|  |  |  | 	 *								PHPExcel_Calculation_Functions::COMPATIBILITY_EXCEL			'Excel' | 
					
						
							|  |  |  | 	 *								PHPExcel_Calculation_Functions::COMPATIBILITY_GNUMERIC		'Gnumeric' | 
					
						
							|  |  |  | 	 *								PHPExcel_Calculation_Functions::COMPATIBILITY_OPENOFFICE	'OpenOfficeCalc' | 
					
						
							|  |  |  | 	 */ | 
					
						
							|  |  |  | 	public static function getCompatibilityMode() { | 
					
						
							|  |  |  | 		return self::$compatibilityMode; | 
					
						
							|  |  |  | 	}	//	function getCompatibilityMode()
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/** | 
					
						
							| 
									
										
										
										
											2012-03-11 17:58:38 +00:00
										 |  |  | 	 * Set the Return Date Format used by functions that return a date/time (Excel, PHP Serialized Numeric or PHP Object) | 
					
						
							| 
									
										
										
										
											2010-08-26 19:14:53 +00:00
										 |  |  | 	 * | 
					
						
							| 
									
										
										
										
											2012-03-11 17:58:38 +00:00
										 |  |  | 	 * @access	public | 
					
						
							|  |  |  | 	 * @category Function Configuration | 
					
						
							|  |  |  | 	 * @param	 string	$returnDateType			Return Date Format | 
					
						
							| 
									
										
										
										
											2010-08-26 19:14:53 +00:00
										 |  |  | 	 *												Permitted values are: | 
					
						
							|  |  |  | 	 *													PHPExcel_Calculation_Functions::RETURNDATE_PHP_NUMERIC		'P' | 
					
						
							|  |  |  | 	 *													PHPExcel_Calculation_Functions::RETURNDATE_PHP_OBJECT		'O' | 
					
						
							|  |  |  | 	 *													PHPExcel_Calculation_Functions::RETURNDATE_EXCEL			'E' | 
					
						
							| 
									
										
										
										
											2012-03-11 17:58:38 +00:00
										 |  |  | 	 * @return	 boolean							Success or failure | 
					
						
							| 
									
										
										
										
											2010-08-26 19:14:53 +00:00
										 |  |  | 	 */ | 
					
						
							|  |  |  | 	public static function setReturnDateType($returnDateType) { | 
					
						
							|  |  |  | 		if (($returnDateType == self::RETURNDATE_PHP_NUMERIC) || | 
					
						
							|  |  |  | 			($returnDateType == self::RETURNDATE_PHP_OBJECT) || | 
					
						
							|  |  |  | 			($returnDateType == self::RETURNDATE_EXCEL)) { | 
					
						
							|  |  |  | 			self::$ReturnDateType = $returnDateType; | 
					
						
							|  |  |  | 			return True; | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 		return False; | 
					
						
							|  |  |  | 	}	//	function setReturnDateType()
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/** | 
					
						
							| 
									
										
										
										
											2012-03-11 17:58:38 +00:00
										 |  |  | 	 * Return the current Return Date Format for functions that return a date/time (Excel, PHP Serialized Numeric or PHP Object) | 
					
						
							| 
									
										
										
										
											2010-08-26 19:14:53 +00:00
										 |  |  | 	 * | 
					
						
							| 
									
										
										
										
											2012-03-11 17:58:38 +00:00
										 |  |  | 	 * @access	public | 
					
						
							|  |  |  | 	 * @category Function Configuration | 
					
						
							|  |  |  | 	 * @return	 string		Return Date Format | 
					
						
							| 
									
										
										
										
											2010-08-26 19:14:53 +00:00
										 |  |  | 	 *							Possible Return values are: | 
					
						
							|  |  |  | 	 *								PHPExcel_Calculation_Functions::RETURNDATE_PHP_NUMERIC		'P' | 
					
						
							|  |  |  | 	 *								PHPExcel_Calculation_Functions::RETURNDATE_PHP_OBJECT		'O' | 
					
						
							|  |  |  | 	 *								PHPExcel_Calculation_Functions::RETURNDATE_EXCEL			'E' | 
					
						
							|  |  |  | 	 */ | 
					
						
							|  |  |  | 	public static function getReturnDateType() { | 
					
						
							|  |  |  | 		return self::$ReturnDateType; | 
					
						
							|  |  |  | 	}	//	function getReturnDateType()
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/** | 
					
						
							| 
									
										
										
										
											2012-03-11 17:58:38 +00:00
										 |  |  | 	 * DUMMY | 
					
						
							| 
									
										
										
										
											2010-08-26 19:14:53 +00:00
										 |  |  | 	 * | 
					
						
							| 
									
										
										
										
											2012-03-11 17:58:38 +00:00
										 |  |  | 	 * @access	public | 
					
						
							|  |  |  | 	 * @category Error Returns | 
					
						
							|  |  |  | 	 * @return	string	#Not Yet Implemented
 | 
					
						
							| 
									
										
										
										
											2010-08-26 19:14:53 +00:00
										 |  |  | 	 */ | 
					
						
							|  |  |  | 	public static function DUMMY() { | 
					
						
							|  |  |  | 		return '#Not Yet Implemented'; | 
					
						
							|  |  |  | 	}	//	function DUMMY()
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-12-02 17:56:33 +00:00
										 |  |  | 	/** | 
					
						
							| 
									
										
										
										
											2012-03-11 17:58:38 +00:00
										 |  |  | 	 * DIV0 | 
					
						
							| 
									
										
										
										
											2010-12-02 17:56:33 +00:00
										 |  |  | 	 * | 
					
						
							| 
									
										
										
										
											2012-03-11 17:58:38 +00:00
										 |  |  | 	 * @access	public | 
					
						
							|  |  |  | 	 * @category Error Returns | 
					
						
							|  |  |  | 	 * @return	string	#Not Yet Implemented
 | 
					
						
							| 
									
										
										
										
											2010-12-02 17:56:33 +00:00
										 |  |  | 	 */ | 
					
						
							|  |  |  | 	public static function DIV0() { | 
					
						
							|  |  |  | 		return self::$_errorCodes['divisionbyzero']; | 
					
						
							|  |  |  | 	}	//	function DIV0()
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-08-26 19:14:53 +00:00
										 |  |  | 	/** | 
					
						
							| 
									
										
										
										
											2012-03-11 17:58:38 +00:00
										 |  |  | 	 * NA | 
					
						
							| 
									
										
										
										
											2010-08-26 19:14:53 +00:00
										 |  |  | 	 * | 
					
						
							| 
									
										
										
										
											2012-03-11 17:58:38 +00:00
										 |  |  | 	 * Excel Function: | 
					
						
							| 
									
										
										
										
											2010-08-26 19:14:53 +00:00
										 |  |  | 	 *		=NA() | 
					
						
							|  |  |  | 	 * | 
					
						
							| 
									
										
										
										
											2012-03-11 17:58:38 +00:00
										 |  |  | 	 * Returns the error value #N/A
 | 
					
						
							| 
									
										
										
										
											2010-08-26 19:14:53 +00:00
										 |  |  | 	 *		#N/A is the error value that means "no value is available."
 | 
					
						
							|  |  |  | 	 * | 
					
						
							| 
									
										
										
										
											2012-03-11 17:58:38 +00:00
										 |  |  | 	 * @access	public | 
					
						
							|  |  |  | 	 * @category Logical Functions | 
					
						
							|  |  |  | 	 * @return	string	#N/A!
 | 
					
						
							| 
									
										
										
										
											2010-08-26 19:14:53 +00:00
										 |  |  | 	 */ | 
					
						
							|  |  |  | 	public static function NA() { | 
					
						
							|  |  |  | 		return self::$_errorCodes['na']; | 
					
						
							|  |  |  | 	}	//	function NA()
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/** | 
					
						
							| 
									
										
										
										
											2012-03-11 17:58:38 +00:00
										 |  |  | 	 * NaN | 
					
						
							| 
									
										
										
										
											2010-08-26 19:14:53 +00:00
										 |  |  | 	 * | 
					
						
							| 
									
										
										
										
											2012-03-11 17:58:38 +00:00
										 |  |  | 	 * Returns the error value #NUM!
 | 
					
						
							| 
									
										
										
										
											2010-08-26 19:14:53 +00:00
										 |  |  | 	 * | 
					
						
							| 
									
										
										
										
											2012-03-11 17:58:38 +00:00
										 |  |  | 	 * @access	public | 
					
						
							|  |  |  | 	 * @category Error Returns | 
					
						
							|  |  |  | 	 * @return	string	#NUM!
 | 
					
						
							| 
									
										
										
										
											2010-08-26 19:14:53 +00:00
										 |  |  | 	 */ | 
					
						
							|  |  |  | 	public static function NaN() { | 
					
						
							|  |  |  | 		return self::$_errorCodes['num']; | 
					
						
							| 
									
										
										
										
											2010-12-02 17:56:33 +00:00
										 |  |  | 	}	//	function NaN()
 | 
					
						
							| 
									
										
										
										
											2010-08-26 19:14:53 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/** | 
					
						
							| 
									
										
										
										
											2012-03-11 17:58:38 +00:00
										 |  |  | 	 * NAME | 
					
						
							| 
									
										
										
										
											2010-08-26 19:14:53 +00:00
										 |  |  | 	 * | 
					
						
							| 
									
										
										
										
											2012-03-11 17:58:38 +00:00
										 |  |  | 	 * Returns the error value #NAME?
 | 
					
						
							| 
									
										
										
										
											2010-08-26 19:14:53 +00:00
										 |  |  | 	 * | 
					
						
							| 
									
										
										
										
											2012-03-11 17:58:38 +00:00
										 |  |  | 	 * @access	public | 
					
						
							|  |  |  | 	 * @category Error Returns | 
					
						
							|  |  |  | 	 * @return	string	#NAME?
 | 
					
						
							| 
									
										
										
										
											2010-08-26 19:14:53 +00:00
										 |  |  | 	 */ | 
					
						
							|  |  |  | 	public static function NAME() { | 
					
						
							|  |  |  | 		return self::$_errorCodes['name']; | 
					
						
							|  |  |  | 	}	//	function NAME()
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/** | 
					
						
							| 
									
										
										
										
											2012-03-11 17:58:38 +00:00
										 |  |  | 	 * REF | 
					
						
							| 
									
										
										
										
											2010-08-26 19:14:53 +00:00
										 |  |  | 	 * | 
					
						
							| 
									
										
										
										
											2012-03-11 17:58:38 +00:00
										 |  |  | 	 * Returns the error value #REF!
 | 
					
						
							| 
									
										
										
										
											2010-08-26 19:14:53 +00:00
										 |  |  | 	 * | 
					
						
							| 
									
										
										
										
											2012-03-11 17:58:38 +00:00
										 |  |  | 	 * @access	public | 
					
						
							|  |  |  | 	 * @category Error Returns | 
					
						
							|  |  |  | 	 * @return	string	#REF!
 | 
					
						
							| 
									
										
										
										
											2010-08-26 19:14:53 +00:00
										 |  |  | 	 */ | 
					
						
							|  |  |  | 	public static function REF() { | 
					
						
							|  |  |  | 		return self::$_errorCodes['reference']; | 
					
						
							|  |  |  | 	}	//	function REF()
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-12-02 17:56:33 +00:00
										 |  |  | 	/** | 
					
						
							| 
									
										
										
										
											2012-03-11 17:58:38 +00:00
										 |  |  | 	 * NULL | 
					
						
							| 
									
										
										
										
											2010-12-02 17:56:33 +00:00
										 |  |  | 	 * | 
					
						
							| 
									
										
										
										
											2012-03-11 17:58:38 +00:00
										 |  |  | 	 * Returns the error value #NULL!
 | 
					
						
							| 
									
										
										
										
											2010-12-02 17:56:33 +00:00
										 |  |  | 	 * | 
					
						
							| 
									
										
										
										
											2012-03-11 17:58:38 +00:00
										 |  |  | 	 * @access	public | 
					
						
							|  |  |  | 	 * @category Error Returns | 
					
						
							|  |  |  | 	 * @return	string	#REF!
 | 
					
						
							| 
									
										
										
										
											2010-12-02 17:56:33 +00:00
										 |  |  | 	 */ | 
					
						
							|  |  |  | 	public static function NULL() { | 
					
						
							|  |  |  | 		return self::$_errorCodes['null']; | 
					
						
							|  |  |  | 	}	//	function NULL()
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-08-26 19:14:53 +00:00
										 |  |  | 	/** | 
					
						
							| 
									
										
										
										
											2012-03-11 17:58:38 +00:00
										 |  |  | 	 * VALUE | 
					
						
							| 
									
										
										
										
											2010-08-26 19:14:53 +00:00
										 |  |  | 	 * | 
					
						
							| 
									
										
										
										
											2012-03-11 17:58:38 +00:00
										 |  |  | 	 * Returns the error value #VALUE!
 | 
					
						
							| 
									
										
										
										
											2010-08-26 19:14:53 +00:00
										 |  |  | 	 * | 
					
						
							| 
									
										
										
										
											2012-03-11 17:58:38 +00:00
										 |  |  | 	 * @access	public | 
					
						
							|  |  |  | 	 * @category Error Returns | 
					
						
							|  |  |  | 	 * @return	string	#VALUE!
 | 
					
						
							| 
									
										
										
										
											2010-08-26 19:14:53 +00:00
										 |  |  | 	 */ | 
					
						
							|  |  |  | 	public static function VALUE() { | 
					
						
							|  |  |  | 		return self::$_errorCodes['value']; | 
					
						
							|  |  |  | 	}	//	function VALUE()
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-12-02 17:56:33 +00:00
										 |  |  | 	public static function isMatrixValue($idx) { | 
					
						
							| 
									
										
										
										
											2010-08-26 19:14:53 +00:00
										 |  |  | 		return ((substr_count($idx,'.') <= 1) || (preg_match('/\.[A-Z]/',$idx) > 0)); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-12-02 17:56:33 +00:00
										 |  |  | 	public static function isValue($idx) { | 
					
						
							| 
									
										
										
										
											2010-08-26 19:14:53 +00:00
										 |  |  | 		return (substr_count($idx,'.') == 0); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-12-02 17:56:33 +00:00
										 |  |  | 	public static function isCellValue($idx) { | 
					
						
							| 
									
										
										
										
											2010-08-26 19:14:53 +00:00
										 |  |  | 		return (substr_count($idx,'.') > 1); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-12-02 17:56:33 +00:00
										 |  |  | 	public static function _ifCondition($condition) { | 
					
						
							|  |  |  | 		$condition	= PHPExcel_Calculation_Functions::flattenSingleValue($condition); | 
					
						
							| 
									
										
										
										
											2013-05-24 08:19:13 +00:00
										 |  |  | 		if (!isset($condition{0})) | 
					
						
							|  |  |  | 			$condition = '=""'; | 
					
						
							| 
									
										
										
										
											2010-12-02 17:56:33 +00:00
										 |  |  | 		if (!in_array($condition{0},array('>', '<', '='))) { | 
					
						
							|  |  |  | 			if (!is_numeric($condition)) { $condition = PHPExcel_Calculation::_wrapResult(strtoupper($condition)); } | 
					
						
							|  |  |  | 			return '='.$condition; | 
					
						
							|  |  |  | 		} else { | 
					
						
							|  |  |  | 			preg_match('/([<>=]+)(.*)/',$condition,$matches); | 
					
						
							|  |  |  | 			list(,$operator,$operand) = $matches; | 
					
						
							|  |  |  | 			if (!is_numeric($operand)) { $operand = PHPExcel_Calculation::_wrapResult(strtoupper($operand)); } | 
					
						
							|  |  |  | 			return $operator.$operand; | 
					
						
							| 
									
										
										
										
											2010-08-26 19:14:53 +00:00
										 |  |  | 		} | 
					
						
							| 
									
										
										
										
											2010-12-02 17:56:33 +00:00
										 |  |  | 	}	//	function _ifCondition()
 | 
					
						
							| 
									
										
										
										
											2010-08-26 19:14:53 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/** | 
					
						
							| 
									
										
										
										
											2012-03-11 17:58:38 +00:00
										 |  |  | 	 * ERROR_TYPE | 
					
						
							| 
									
										
										
										
											2010-08-26 19:14:53 +00:00
										 |  |  | 	 * | 
					
						
							| 
									
										
										
										
											2012-03-11 17:58:38 +00:00
										 |  |  | 	 * @param	mixed	$value	Value to check | 
					
						
							|  |  |  | 	 * @return	boolean | 
					
						
							| 
									
										
										
										
											2010-08-26 19:14:53 +00:00
										 |  |  | 	 */ | 
					
						
							| 
									
										
										
										
											2010-12-02 17:56:33 +00:00
										 |  |  | 	public static function ERROR_TYPE($value = '') { | 
					
						
							|  |  |  | 		$value	= self::flattenSingleValue($value); | 
					
						
							| 
									
										
										
										
											2010-08-26 19:14:53 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-12-02 17:56:33 +00:00
										 |  |  | 		$i = 1; | 
					
						
							|  |  |  | 		foreach(self::$_errorCodes as $errorCode) { | 
					
						
							| 
									
										
										
										
											2012-01-26 20:06:35 +00:00
										 |  |  | 			if ($value === $errorCode) { | 
					
						
							| 
									
										
										
										
											2010-12-02 17:56:33 +00:00
										 |  |  | 				return $i; | 
					
						
							| 
									
										
										
										
											2010-08-26 19:14:53 +00:00
										 |  |  | 			} | 
					
						
							| 
									
										
										
										
											2010-12-02 17:56:33 +00:00
										 |  |  | 			++$i; | 
					
						
							| 
									
										
										
										
											2010-08-26 19:14:53 +00:00
										 |  |  | 		} | 
					
						
							| 
									
										
										
										
											2012-01-26 20:06:35 +00:00
										 |  |  | 		return self::NA(); | 
					
						
							| 
									
										
										
										
											2010-12-02 17:56:33 +00:00
										 |  |  | 	}	//	function ERROR_TYPE()
 | 
					
						
							| 
									
										
										
										
											2010-08-26 19:14:53 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/** | 
					
						
							| 
									
										
										
										
											2012-03-11 17:58:38 +00:00
										 |  |  | 	 * IS_BLANK | 
					
						
							| 
									
										
										
										
											2010-08-26 19:14:53 +00:00
										 |  |  | 	 * | 
					
						
							| 
									
										
										
										
											2012-03-11 17:58:38 +00:00
										 |  |  | 	 * @param	mixed	$value	Value to check | 
					
						
							|  |  |  | 	 * @return	boolean | 
					
						
							| 
									
										
										
										
											2010-08-26 19:14:53 +00:00
										 |  |  | 	 */ | 
					
						
							| 
									
										
										
										
											2012-01-26 20:06:35 +00:00
										 |  |  | 	public static function IS_BLANK($value = NULL) { | 
					
						
							| 
									
										
										
										
											2010-12-02 17:56:33 +00:00
										 |  |  | 		if (!is_null($value)) { | 
					
						
							|  |  |  | 			$value	= self::flattenSingleValue($value); | 
					
						
							|  |  |  | 		} | 
					
						
							| 
									
										
										
										
											2010-08-26 19:14:53 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-12-02 17:56:33 +00:00
										 |  |  | 		return is_null($value); | 
					
						
							|  |  |  | 	}	//	function IS_BLANK()
 | 
					
						
							| 
									
										
										
										
											2010-08-26 19:14:53 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/** | 
					
						
							| 
									
										
										
										
											2012-03-11 17:58:38 +00:00
										 |  |  | 	 * IS_ERR | 
					
						
							| 
									
										
										
										
											2010-08-26 19:14:53 +00:00
										 |  |  | 	 * | 
					
						
							| 
									
										
										
										
											2012-03-11 17:58:38 +00:00
										 |  |  | 	 * @param	mixed	$value	Value to check | 
					
						
							|  |  |  | 	 * @return	boolean | 
					
						
							| 
									
										
										
										
											2010-08-26 19:14:53 +00:00
										 |  |  | 	 */ | 
					
						
							| 
									
										
										
										
											2010-12-02 17:56:33 +00:00
										 |  |  | 	public static function IS_ERR($value = '') { | 
					
						
							|  |  |  | 		$value		= self::flattenSingleValue($value); | 
					
						
							| 
									
										
										
										
											2010-08-26 19:14:53 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-12-02 17:56:33 +00:00
										 |  |  | 		return self::IS_ERROR($value) && (!self::IS_NA($value)); | 
					
						
							|  |  |  | 	}	//	function IS_ERR()
 | 
					
						
							| 
									
										
										
										
											2010-08-26 19:14:53 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/** | 
					
						
							| 
									
										
										
										
											2012-03-11 17:58:38 +00:00
										 |  |  | 	 * IS_ERROR | 
					
						
							| 
									
										
										
										
											2010-08-26 19:14:53 +00:00
										 |  |  | 	 * | 
					
						
							| 
									
										
										
										
											2012-03-11 17:58:38 +00:00
										 |  |  | 	 * @param	mixed	$value	Value to check | 
					
						
							|  |  |  | 	 * @return	boolean | 
					
						
							| 
									
										
										
										
											2010-08-26 19:14:53 +00:00
										 |  |  | 	 */ | 
					
						
							| 
									
										
										
										
											2010-12-02 17:56:33 +00:00
										 |  |  | 	public static function IS_ERROR($value = '') { | 
					
						
							|  |  |  | 		$value		= self::flattenSingleValue($value); | 
					
						
							| 
									
										
										
										
											2010-08-26 19:14:53 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-01-26 20:06:35 +00:00
										 |  |  | 		if (!is_string($value)) | 
					
						
							|  |  |  | 			return false; | 
					
						
							| 
									
										
										
										
											2010-12-02 17:56:33 +00:00
										 |  |  | 		return in_array($value, array_values(self::$_errorCodes)); | 
					
						
							|  |  |  | 	}	//	function IS_ERROR()
 | 
					
						
							| 
									
										
										
										
											2010-08-26 19:14:53 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/** | 
					
						
							| 
									
										
										
										
											2012-03-11 17:58:38 +00:00
										 |  |  | 	 * IS_NA | 
					
						
							| 
									
										
										
										
											2010-08-26 19:14:53 +00:00
										 |  |  | 	 * | 
					
						
							| 
									
										
										
										
											2012-03-11 17:58:38 +00:00
										 |  |  | 	 * @param	mixed	$value	Value to check | 
					
						
							|  |  |  | 	 * @return	boolean | 
					
						
							| 
									
										
										
										
											2010-08-26 19:14:53 +00:00
										 |  |  | 	 */ | 
					
						
							| 
									
										
										
										
											2010-12-02 17:56:33 +00:00
										 |  |  | 	public static function IS_NA($value = '') { | 
					
						
							|  |  |  | 		$value		= self::flattenSingleValue($value); | 
					
						
							| 
									
										
										
										
											2010-08-26 19:14:53 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-01-26 20:06:35 +00:00
										 |  |  | 		return ($value === self::NA()); | 
					
						
							| 
									
										
										
										
											2010-12-02 17:56:33 +00:00
										 |  |  | 	}	//	function IS_NA()
 | 
					
						
							| 
									
										
										
										
											2010-08-26 19:14:53 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/** | 
					
						
							| 
									
										
										
										
											2012-03-11 17:58:38 +00:00
										 |  |  | 	 * IS_EVEN | 
					
						
							| 
									
										
										
										
											2010-08-26 19:14:53 +00:00
										 |  |  | 	 * | 
					
						
							| 
									
										
										
										
											2012-03-11 17:58:38 +00:00
										 |  |  | 	 * @param	mixed	$value	Value to check | 
					
						
							|  |  |  | 	 * @return	boolean | 
					
						
							| 
									
										
										
										
											2010-08-26 19:14:53 +00:00
										 |  |  | 	 */ | 
					
						
							| 
									
										
										
										
											2012-01-26 20:06:35 +00:00
										 |  |  | 	public static function IS_EVEN($value = NULL) { | 
					
						
							|  |  |  | 		$value = self::flattenSingleValue($value); | 
					
						
							| 
									
										
										
										
											2010-08-26 19:14:53 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-01-26 20:06:35 +00:00
										 |  |  | 		if ($value === NULL) | 
					
						
							|  |  |  | 			return self::NAME(); | 
					
						
							|  |  |  | 		if ((is_bool($value)) || ((is_string($value)) && (!is_numeric($value)))) | 
					
						
							|  |  |  | 			return self::VALUE(); | 
					
						
							| 
									
										
										
										
											2010-12-02 17:56:33 +00:00
										 |  |  | 		return ($value % 2 == 0); | 
					
						
							|  |  |  | 	}	//	function IS_EVEN()
 | 
					
						
							| 
									
										
										
										
											2010-08-26 19:14:53 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/** | 
					
						
							| 
									
										
										
										
											2012-03-11 17:58:38 +00:00
										 |  |  | 	 * IS_ODD | 
					
						
							| 
									
										
										
										
											2010-08-26 19:14:53 +00:00
										 |  |  | 	 * | 
					
						
							| 
									
										
										
										
											2012-03-11 17:58:38 +00:00
										 |  |  | 	 * @param	mixed	$value	Value to check | 
					
						
							|  |  |  | 	 * @return	boolean | 
					
						
							| 
									
										
										
										
											2010-08-26 19:14:53 +00:00
										 |  |  | 	 */ | 
					
						
							| 
									
										
										
										
											2012-01-26 20:06:35 +00:00
										 |  |  | 	public static function IS_ODD($value = NULL) { | 
					
						
							|  |  |  | 		$value = self::flattenSingleValue($value); | 
					
						
							| 
									
										
										
										
											2010-08-26 19:14:53 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-01-26 20:06:35 +00:00
										 |  |  | 		if ($value === NULL) | 
					
						
							|  |  |  | 			return self::NAME(); | 
					
						
							|  |  |  | 		if ((is_bool($value)) || ((is_string($value)) && (!is_numeric($value)))) | 
					
						
							|  |  |  | 			return self::VALUE(); | 
					
						
							| 
									
										
										
										
											2010-12-02 17:56:33 +00:00
										 |  |  | 		return (abs($value) % 2 == 1); | 
					
						
							|  |  |  | 	}	//	function IS_ODD()
 | 
					
						
							| 
									
										
										
										
											2010-08-26 19:14:53 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/** | 
					
						
							| 
									
										
										
										
											2012-03-11 17:58:38 +00:00
										 |  |  | 	 * IS_NUMBER | 
					
						
							| 
									
										
										
										
											2010-08-26 19:14:53 +00:00
										 |  |  | 	 * | 
					
						
							| 
									
										
										
										
											2012-03-11 17:58:38 +00:00
										 |  |  | 	 * @param	mixed	$value		Value to check | 
					
						
							|  |  |  | 	 * @return	boolean | 
					
						
							| 
									
										
										
										
											2010-08-26 19:14:53 +00:00
										 |  |  | 	 */ | 
					
						
							| 
									
										
										
										
											2012-01-26 20:06:35 +00:00
										 |  |  | 	public static function IS_NUMBER($value = NULL) { | 
					
						
							| 
									
										
										
										
											2010-12-02 17:56:33 +00:00
										 |  |  | 		$value		= self::flattenSingleValue($value); | 
					
						
							| 
									
										
										
										
											2010-08-26 19:14:53 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-12-02 17:56:33 +00:00
										 |  |  | 		if (is_string($value)) { | 
					
						
							|  |  |  | 			return False; | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 		return is_numeric($value); | 
					
						
							|  |  |  | 	}	//	function IS_NUMBER()
 | 
					
						
							| 
									
										
										
										
											2010-08-26 19:14:53 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/** | 
					
						
							| 
									
										
										
										
											2012-03-11 17:58:38 +00:00
										 |  |  | 	 * IS_LOGICAL | 
					
						
							| 
									
										
										
										
											2010-08-26 19:14:53 +00:00
										 |  |  | 	 * | 
					
						
							| 
									
										
										
										
											2012-03-11 17:58:38 +00:00
										 |  |  | 	 * @param	mixed	$value		Value to check | 
					
						
							|  |  |  | 	 * @return	boolean | 
					
						
							| 
									
										
										
										
											2010-08-26 19:14:53 +00:00
										 |  |  | 	 */ | 
					
						
							| 
									
										
										
										
											2012-01-26 20:06:35 +00:00
										 |  |  | 	public static function IS_LOGICAL($value = NULL) { | 
					
						
							| 
									
										
										
										
											2010-12-02 17:56:33 +00:00
										 |  |  | 		$value		= self::flattenSingleValue($value); | 
					
						
							| 
									
										
										
										
											2010-08-26 19:14:53 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-12-02 17:56:33 +00:00
										 |  |  | 		return is_bool($value); | 
					
						
							|  |  |  | 	}	//	function IS_LOGICAL()
 | 
					
						
							| 
									
										
										
										
											2010-08-26 19:14:53 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/** | 
					
						
							| 
									
										
										
										
											2012-03-11 17:58:38 +00:00
										 |  |  | 	 * IS_TEXT | 
					
						
							| 
									
										
										
										
											2010-08-26 19:14:53 +00:00
										 |  |  | 	 * | 
					
						
							| 
									
										
										
										
											2012-03-11 17:58:38 +00:00
										 |  |  | 	 * @param	mixed	$value		Value to check | 
					
						
							|  |  |  | 	 * @return	boolean | 
					
						
							| 
									
										
										
										
											2010-08-26 19:14:53 +00:00
										 |  |  | 	 */ | 
					
						
							| 
									
										
										
										
											2012-01-26 20:06:35 +00:00
										 |  |  | 	public static function IS_TEXT($value = NULL) { | 
					
						
							| 
									
										
										
										
											2010-12-02 17:56:33 +00:00
										 |  |  | 		$value		= self::flattenSingleValue($value); | 
					
						
							| 
									
										
										
										
											2010-08-26 19:14:53 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-01-26 20:06:35 +00:00
										 |  |  | 		return (is_string($value) && !self::IS_ERROR($value)); | 
					
						
							| 
									
										
										
										
											2010-12-02 17:56:33 +00:00
										 |  |  | 	}	//	function IS_TEXT()
 | 
					
						
							| 
									
										
										
										
											2010-08-26 19:14:53 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/** | 
					
						
							| 
									
										
										
										
											2012-03-11 17:58:38 +00:00
										 |  |  | 	 * IS_NONTEXT | 
					
						
							| 
									
										
										
										
											2010-08-26 19:14:53 +00:00
										 |  |  | 	 * | 
					
						
							| 
									
										
										
										
											2012-03-11 17:58:38 +00:00
										 |  |  | 	 * @param	mixed	$value		Value to check | 
					
						
							|  |  |  | 	 * @return	boolean | 
					
						
							| 
									
										
										
										
											2010-08-26 19:14:53 +00:00
										 |  |  | 	 */ | 
					
						
							| 
									
										
										
										
											2012-01-26 20:06:35 +00:00
										 |  |  | 	public static function IS_NONTEXT($value = NULL) { | 
					
						
							| 
									
										
										
										
											2010-12-02 17:56:33 +00:00
										 |  |  | 		return !self::IS_TEXT($value); | 
					
						
							|  |  |  | 	}	//	function IS_NONTEXT()
 | 
					
						
							| 
									
										
										
										
											2010-08-26 19:14:53 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/** | 
					
						
							| 
									
										
										
										
											2012-03-11 17:58:38 +00:00
										 |  |  | 	 * VERSION | 
					
						
							| 
									
										
										
										
											2010-08-26 19:14:53 +00:00
										 |  |  | 	 * | 
					
						
							| 
									
										
										
										
											2012-03-11 17:58:38 +00:00
										 |  |  | 	 * @return	string	Version information | 
					
						
							| 
									
										
										
										
											2010-08-26 19:14:53 +00:00
										 |  |  | 	 */ | 
					
						
							| 
									
										
										
										
											2010-12-02 17:56:33 +00:00
										 |  |  | 	public static function VERSION() { | 
					
						
							|  |  |  | 		return 'PHPExcel ##VERSION##, ##DATE##'; | 
					
						
							|  |  |  | 	}	//	function VERSION()
 | 
					
						
							| 
									
										
										
										
											2010-08-26 19:14:53 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/** | 
					
						
							| 
									
										
										
										
											2012-03-11 17:58:38 +00:00
										 |  |  | 	 * N | 
					
						
							| 
									
										
										
										
											2010-08-26 19:14:53 +00:00
										 |  |  | 	 * | 
					
						
							| 
									
										
										
										
											2012-03-11 17:58:38 +00:00
										 |  |  | 	 * Returns a value converted to a number | 
					
						
							| 
									
										
										
										
											2010-08-26 19:14:53 +00:00
										 |  |  | 	 * | 
					
						
							| 
									
										
										
										
											2012-03-11 17:58:38 +00:00
										 |  |  | 	 * @param	value		The value you want converted | 
					
						
							|  |  |  | 	 * @return	number		N converts values listed in the following table | 
					
						
							| 
									
										
										
										
											2010-12-02 17:56:33 +00:00
										 |  |  | 	 *		If value is or refers to N returns | 
					
						
							|  |  |  | 	 *		A number			That number | 
					
						
							|  |  |  | 	 *		A date				The serial number of that date | 
					
						
							|  |  |  | 	 *		TRUE				1 | 
					
						
							|  |  |  | 	 *		FALSE				0 | 
					
						
							|  |  |  | 	 *		An error value		The error value | 
					
						
							|  |  |  | 	 *		Anything else		0 | 
					
						
							| 
									
										
										
										
											2010-08-26 19:14:53 +00:00
										 |  |  | 	 */ | 
					
						
							| 
									
										
										
										
											2012-01-26 20:06:35 +00:00
										 |  |  | 	public static function N($value = NULL) { | 
					
						
							| 
									
										
										
										
											2010-08-26 19:14:53 +00:00
										 |  |  | 		while (is_array($value)) { | 
					
						
							|  |  |  | 			$value = array_shift($value); | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		switch (gettype($value)) { | 
					
						
							|  |  |  | 			case 'double'	: | 
					
						
							|  |  |  | 			case 'float'	: | 
					
						
							|  |  |  | 			case 'integer'	: | 
					
						
							|  |  |  | 				return $value; | 
					
						
							|  |  |  | 				break; | 
					
						
							|  |  |  | 			case 'boolean'	: | 
					
						
							|  |  |  | 				return (integer) $value; | 
					
						
							|  |  |  | 				break; | 
					
						
							|  |  |  | 			case 'string'	: | 
					
						
							|  |  |  | 				//	Errors
 | 
					
						
							|  |  |  | 				if ((strlen($value) > 0) && ($value{0} == '#')) { | 
					
						
							|  |  |  | 					return $value; | 
					
						
							|  |  |  | 				} | 
					
						
							|  |  |  | 				break; | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 		return 0; | 
					
						
							|  |  |  | 	}	//	function N()
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/** | 
					
						
							| 
									
										
										
										
											2012-03-11 17:58:38 +00:00
										 |  |  | 	 * TYPE | 
					
						
							| 
									
										
										
										
											2010-08-26 19:14:53 +00:00
										 |  |  | 	 * | 
					
						
							| 
									
										
										
										
											2012-03-11 17:58:38 +00:00
										 |  |  | 	 * Returns a number that identifies the type of a value | 
					
						
							| 
									
										
										
										
											2010-08-26 19:14:53 +00:00
										 |  |  | 	 * | 
					
						
							| 
									
										
										
										
											2012-03-11 17:58:38 +00:00
										 |  |  | 	 * @param	value		The value you want tested | 
					
						
							|  |  |  | 	 * @return	number		N converts values listed in the following table | 
					
						
							| 
									
										
										
										
											2010-08-26 19:14:53 +00:00
										 |  |  | 	 *		If value is or refers to N returns | 
					
						
							|  |  |  | 	 *		A number			1 | 
					
						
							|  |  |  | 	 *		Text				2 | 
					
						
							|  |  |  | 	 *		Logical Value		4 | 
					
						
							|  |  |  | 	 *		An error value		16 | 
					
						
							|  |  |  | 	 *		Array or Matrix		64 | 
					
						
							|  |  |  | 	 */ | 
					
						
							| 
									
										
										
										
											2012-01-26 20:06:35 +00:00
										 |  |  | 	public static function TYPE($value = NULL) { | 
					
						
							| 
									
										
										
										
											2010-08-26 19:14:53 +00:00
										 |  |  | 		$value	= self::flattenArrayIndexed($value); | 
					
						
							|  |  |  | 		if (is_array($value) && (count($value) > 1)) { | 
					
						
							|  |  |  | 			$a = array_keys($value); | 
					
						
							|  |  |  | 			$a = array_pop($a); | 
					
						
							|  |  |  | 			//	Range of cells is an error
 | 
					
						
							|  |  |  | 			if (self::isCellValue($a)) { | 
					
						
							|  |  |  | 				return 16; | 
					
						
							|  |  |  | 			//	Test for Matrix
 | 
					
						
							|  |  |  | 			} elseif (self::isMatrixValue($a)) { | 
					
						
							|  |  |  | 				return 64; | 
					
						
							|  |  |  | 			} | 
					
						
							| 
									
										
										
										
											2012-01-16 12:34:22 +00:00
										 |  |  | 		} elseif(empty($value)) { | 
					
						
							| 
									
										
										
										
											2010-08-26 19:14:53 +00:00
										 |  |  | 			//	Empty Cell
 | 
					
						
							|  |  |  | 			return 1; | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 		$value	= self::flattenSingleValue($value); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-01-26 20:06:35 +00:00
										 |  |  | 		if (($value === NULL) || (is_float($value)) || (is_int($value))) { | 
					
						
							| 
									
										
										
										
											2010-08-26 19:14:53 +00:00
										 |  |  | 				return 1; | 
					
						
							|  |  |  | 		} elseif(is_bool($value)) { | 
					
						
							|  |  |  | 				return 4; | 
					
						
							|  |  |  | 		} elseif(is_array($value)) { | 
					
						
							|  |  |  | 				return 64; | 
					
						
							|  |  |  | 				break; | 
					
						
							|  |  |  | 		} elseif(is_string($value)) { | 
					
						
							|  |  |  | 			//	Errors
 | 
					
						
							|  |  |  | 			if ((strlen($value) > 0) && ($value{0} == '#')) { | 
					
						
							|  |  |  | 				return 16; | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 			return 2; | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 		return 0; | 
					
						
							|  |  |  | 	}	//	function TYPE()
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/** | 
					
						
							| 
									
										
										
										
											2012-03-11 17:58:38 +00:00
										 |  |  | 	 * Convert a multi-dimensional array to a simple 1-dimensional array | 
					
						
							| 
									
										
										
										
											2010-08-26 19:14:53 +00:00
										 |  |  | 	 * | 
					
						
							| 
									
										
										
										
											2012-03-11 17:58:38 +00:00
										 |  |  | 	 * @param	array	$array	Array to be flattened | 
					
						
							|  |  |  | 	 * @return	array	Flattened array | 
					
						
							| 
									
										
										
										
											2010-08-26 19:14:53 +00:00
										 |  |  | 	 */ | 
					
						
							|  |  |  | 	public static function flattenArray($array) { | 
					
						
							|  |  |  | 		if (!is_array($array)) { | 
					
						
							|  |  |  | 			return (array) $array; | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		$arrayValues = array(); | 
					
						
							|  |  |  | 		foreach ($array as $value) { | 
					
						
							|  |  |  | 			if (is_array($value)) { | 
					
						
							|  |  |  | 				foreach ($value as $val) { | 
					
						
							|  |  |  | 					if (is_array($val)) { | 
					
						
							|  |  |  | 						foreach ($val as $v) { | 
					
						
							|  |  |  | 							$arrayValues[] = $v; | 
					
						
							|  |  |  | 						} | 
					
						
							|  |  |  | 					} else { | 
					
						
							|  |  |  | 						$arrayValues[] = $val; | 
					
						
							|  |  |  | 					} | 
					
						
							|  |  |  | 				} | 
					
						
							|  |  |  | 			} else { | 
					
						
							|  |  |  | 				$arrayValues[] = $value; | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		return $arrayValues; | 
					
						
							|  |  |  | 	}	//	function flattenArray()
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/** | 
					
						
							| 
									
										
										
										
											2012-03-11 17:58:38 +00:00
										 |  |  | 	 * Convert a multi-dimensional array to a simple 1-dimensional array, but retain an element of indexing | 
					
						
							| 
									
										
										
										
											2010-08-26 19:14:53 +00:00
										 |  |  | 	 * | 
					
						
							| 
									
										
										
										
											2012-03-11 17:58:38 +00:00
										 |  |  | 	 * @param	array	$array	Array to be flattened | 
					
						
							|  |  |  | 	 * @return	array	Flattened array | 
					
						
							| 
									
										
										
										
											2010-08-26 19:14:53 +00:00
										 |  |  | 	 */ | 
					
						
							|  |  |  | 	public static function flattenArrayIndexed($array) { | 
					
						
							|  |  |  | 		if (!is_array($array)) { | 
					
						
							|  |  |  | 			return (array) $array; | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		$arrayValues = array(); | 
					
						
							|  |  |  | 		foreach ($array as $k1 => $value) { | 
					
						
							|  |  |  | 			if (is_array($value)) { | 
					
						
							|  |  |  | 				foreach ($value as $k2 => $val) { | 
					
						
							|  |  |  | 					if (is_array($val)) { | 
					
						
							|  |  |  | 						foreach ($val as $k3 => $v) { | 
					
						
							|  |  |  | 							$arrayValues[$k1.'.'.$k2.'.'.$k3] = $v; | 
					
						
							|  |  |  | 						} | 
					
						
							|  |  |  | 					} else { | 
					
						
							|  |  |  | 						$arrayValues[$k1.'.'.$k2] = $val; | 
					
						
							|  |  |  | 					} | 
					
						
							|  |  |  | 				} | 
					
						
							|  |  |  | 			} else { | 
					
						
							|  |  |  | 				$arrayValues[$k1] = $value; | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		return $arrayValues; | 
					
						
							|  |  |  | 	}	//	function flattenArrayIndexed()
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/** | 
					
						
							| 
									
										
										
										
											2012-03-11 17:58:38 +00:00
										 |  |  | 	 * Convert an array to a single scalar value by extracting the first element | 
					
						
							| 
									
										
										
										
											2010-08-26 19:14:53 +00:00
										 |  |  | 	 * | 
					
						
							| 
									
										
										
										
											2012-03-11 17:58:38 +00:00
										 |  |  | 	 * @param	mixed		$value		Array or scalar value | 
					
						
							|  |  |  | 	 * @return	mixed | 
					
						
							| 
									
										
										
										
											2010-08-26 19:14:53 +00:00
										 |  |  | 	 */ | 
					
						
							|  |  |  | 	public static function flattenSingleValue($value = '') { | 
					
						
							|  |  |  | 		while (is_array($value)) { | 
					
						
							|  |  |  | 			$value = array_pop($value); | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		return $value; | 
					
						
							|  |  |  | 	}	//	function flattenSingleValue()
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | }	//	class PHPExcel_Calculation_Functions
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | //
 | 
					
						
							|  |  |  | //	There are a few mathematical functions that aren't available on all versions of PHP for all platforms
 | 
					
						
							|  |  |  | //	These functions aren't available in Windows implementations of PHP prior to version 5.3.0
 | 
					
						
							|  |  |  | //	So we test if they do exist for this version of PHP/operating platform; and if not we create them
 | 
					
						
							|  |  |  | //
 | 
					
						
							|  |  |  | if (!function_exists('acosh')) { | 
					
						
							|  |  |  | 	function acosh($x) { | 
					
						
							|  |  |  | 		return 2 * log(sqrt(($x + 1) / 2) + sqrt(($x - 1) / 2)); | 
					
						
							|  |  |  | 	}	//	function acosh()
 | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | if (!function_exists('asinh')) { | 
					
						
							|  |  |  | 	function asinh($x) { | 
					
						
							|  |  |  | 		return log($x + sqrt(1 + $x * $x)); | 
					
						
							|  |  |  | 	}	//	function asinh()
 | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | if (!function_exists('atanh')) { | 
					
						
							|  |  |  | 	function atanh($x) { | 
					
						
							|  |  |  | 		return (log(1 + $x) - log(1 - $x)) / 2; | 
					
						
							|  |  |  | 	}	//	function atanh()
 | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | //
 | 
					
						
							|  |  |  | //	Strangely, PHP doesn't have a mb_str_replace multibyte function
 | 
					
						
							|  |  |  | //	As we'll only ever use this function with UTF-8 characters, we can simply "hard-code" the character set
 | 
					
						
							|  |  |  | //
 | 
					
						
							|  |  |  | if ((!function_exists('mb_str_replace')) && | 
					
						
							|  |  |  | 	(function_exists('mb_substr')) && (function_exists('mb_strlen')) && (function_exists('mb_strpos'))) { | 
					
						
							|  |  |  | 	function mb_str_replace($search, $replace, $subject) { | 
					
						
							|  |  |  | 		if(is_array($subject)) { | 
					
						
							|  |  |  | 			$ret = array(); | 
					
						
							|  |  |  | 			foreach($subject as $key => $val) { | 
					
						
							|  |  |  | 				$ret[$key] = mb_str_replace($search, $replace, $val); | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 			return $ret; | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		foreach((array) $search as $key => $s) { | 
					
						
							|  |  |  | 			if($s == '') { | 
					
						
							|  |  |  | 				continue; | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 			$r = !is_array($replace) ? $replace : (array_key_exists($key, $replace) ? $replace[$key] : ''); | 
					
						
							|  |  |  | 			$pos = mb_strpos($subject, $s, 0, 'UTF-8'); | 
					
						
							|  |  |  | 			while($pos !== false) { | 
					
						
							|  |  |  | 				$subject = mb_substr($subject, 0, $pos, 'UTF-8') . $r . mb_substr($subject, $pos + mb_strlen($s, 'UTF-8'), 65535, 'UTF-8'); | 
					
						
							|  |  |  | 				$pos = mb_strpos($subject, $s, $pos + mb_strlen($r, 'UTF-8'), 'UTF-8'); | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 		return $subject; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | } |