Java Like Array Implementation!
<?php
/*
* Author : Pragash Jeyaratnam
* Vector Class
* PHP Version 5.2.5
* Contact : pragash_jey@yahoo.com.
*/
class Vector
{
/*
* The number of valid components in this Vector object.
*/
protected $elementCount;
/*
* The array buffer into which the components of the vector are stored.
*/
protected $elementData;
/**Default vector Constructor*/
function __construct()
{
$this->elementData = array();
$this->elementCount = count($this->elementData);
}
/**Append the parameter element to the vector*/
public function add($object)
{
if(!empty($object))
{
$this->elementData[] = $object;
$this->elementCount = count($this->elementData);
return true;
}
else
return false;
}
/*
* Returns true of Vector is empty false otherwise
*/
public function isEmpty()
{
return($this->elementCount==0);
}
/*
* Returns the current size of this Vector
*/
public function size()
{
return $this->elementCount;
}
/*
* Searches for the first occurence of the given argument
**/
public function indexOf($object)
{
if(($index =array_search($object,$this->elementData)) !==false)
return $index;
else
return -1;
}
/*
* This function will retain TRUE if $object is contained
* within the vector else FALSE
*/
public function contains($object)
{
return ($this->indexOf($object)>=0);
}
/*
* Returns Vector Object at index $index
* Error : Null is returned
*/
public function get($index)
{
if($this->checkBound($index))
{
return ($this->elementData[$index]);
}
return NULL;
}
/*
* Sets the object at $index to be $object
**/
public function set($index,$object)
{
if($this->checkBound($index))
{
$this->elementData[$index] =$object ;
return true;
}
return false;
}
/*
* Removes element at $index
**/
public function removeAt($index)
{
if ($this->checkBound($index))
{
for ($i = $index; $i != $this->elementCount - 1; $i++)
{
$this->elementData[$i] = $this->elementData[$i +1];
}
array_pop($this->elementData);
$this->elementCount = count($this->elementData);
return true;
}
else {
return false;
}
}
/**
* Removes all elements from the Vector. Note that this does not
* resize the internal data array.
*/
public function removeAll()
{
if($this->elementCount ==0)
return;
for($i=0;$i<$this->size();$i++)
{
$this->set($i,NULL);
}
}
/*
* This function checks whether index
* is within the array bound
**/
private function checkBound($index)
{
if($index > $this->elementCount-1 || $index < 0)
{
throw new Exception('Array Index Out Of Bound Exception');
return false;
}
return true;
}
/*
*Removes the first element from the Vector
*/
public function removeFirstElement()
{
if($this->elementCount==0)
{
throw new Exception('No Such Element');
}
$test =array_shift($this->elementData);
if(!empty($test))
$this->elementCount = count($this->elementData);
}
}
?>
Tömbkezelő függvények
Bevezetés
Ezekkel a függvényekkel különféle módon változtathatók, módosíthatók a tömbök. A tömbök elengedhetetlenek változók sorozatának tárolásához, rendezéséhez, igazgatásához és azok változtatásához.
A PHP az egy- és többdimenziós tömböket is támogatja, amelyeket akár "manuálisan" vagy valamilyen függvénnyel is létre lehet hozni. Vannak bizonyos adatbázis-kezelő függvények, amelyek adatbázis-lekérdezések alapján töltenek fel tömböket, és vannak, amelyek tömböket adnak vissza.
Nézd át a Tömbök fejezetet, ahol részletes leírást található a PHP-s tömbök megvalósításáról és működéséről. Hasznos információk olvashatók a Tömb operátorok oldalon arról, mi módon lehet még a tömbökön műveleteket végezni.
Követelmények
Az itt leírt függvények használatához semmilyen külső függvénykönyvtár megléte nem szükségeltetik.
Telepítés
Semmilyen telepítés nem szükséges ezen függvények használatához, a PHP alapelemei.
Futásidejű beállítások
Ez a kiterjesztés semmilyen konfigurációs beállításokat nem definiál a php.ini állományban.
Erőforrás típusok
Ez a kiterjesztés semmilyen erőforrás típust nem definiál.
Előre definiált állandók
Az itt felsorolt konstansok mindig elérthetőek, mivel részei a PHP alaptelepítésének.
- CASE_LOWER (integer)
- CASE_LOWER az array_change_key_case() függvény paramétereként használható, és arra utasítja a függvényt, hogy a tömb kulcsait cserélje kisbetűs megfelelőikre. Ez az array_change_key_case() alapértelmezésbeli viselkedése is.
- CASE_UPPER (integer)
- CASE_LOWER az array_change_key_case() függvény paramétereként használható, és arra utasítja a függvényt, hogy a tömb kulcsait cserélje nagybetűs megfelelőikre.
Rendezési irány flag-ek:
- SORT_ASC (integer)
- SORT_ASC - az array_multisort() használja a növekvő sorrend megadására
- SORT_DESC (integer)
- SORT_DESC - az array_multisort() használja a csökkenő sorrend megadására
Rendezés típus flag-ek: bizonyos rendezőfüggvények alkalmazzák
- SORT_REGULAR (integer)
- SORT_REGULAR - hogy a tömbelemek a megszokott módon legyenek sorrendezve.
- SORT_NUMERIC (integer)
- SORT_NUMERIC - hogy a tömbelemek számszerűen értelmezve legyenek sorrendezve.
- SORT_STRING (integer)
- SORT_STRING - hogy a tömbelemek string-ként kerüljenek sorrendezésre.
- SORT_LOCALE_STRING (integer)
- A SORT_LOCALE_STRING az aktuálos locale beállítás figyelembevételével hasonlítja össze a kapott értékeket. Ez a lehetőség a PHP 4.4.0 és 5.0.2 változataival lett bevezetve.
Lásd még
is_array(), explode(), implode(), split() preg_split() és unset()!
Table of Contents
- array_change_key_case — visszaad egy kis vagy nagybetűsre cserélt string indexű tömböt
- array_chunk — feldarabolja a tömböt
- array_combine — Creates an array by using one array for keys and another for its values
- array_count_values — összeszámolja minden érték előfordulását a tömbben
- array_diff_assoc — Computes the difference of arrays with additional index check
- array_diff_key — Computes the difference of arrays using keys for comparison
- array_diff_uassoc — Computes the difference of arrays with additional index check which is performed by a user supplied callback function
- array_diff_ukey — Computes the difference of arrays using a callback function on the keys for comparison
- array_diff — tömbök közti különbséget számolja ki
- array_fill_keys — Fill an array with values, specifying keys
- array_fill — feltölt egy tömböt egy megadott értékkel
- array_filter — Megsszűri a tömb elemeit egy függvény visszahívásával
- array_flip — Felcseréli a tömb elemeit és kulcsait
- array_intersect_assoc — Computes the intersection of arrays with additional index check
- array_intersect_key — Computes the intersection of arrays using keys for comparison
- array_intersect_uassoc — Computes the intersection of arrays with additional index check, compares indexes by a callback function
- array_intersect_ukey — Computes the intersection of arrays using a callback function on the keys for comparison
- array_intersect — kiszámítja a tömbök metszetét
- array_key_exists — ellenőrzi a keresett index/kulcs létezését a tömbben
- array_keys — Visszaadja egy tömb összes indexét
- array_map — Egy függvényt alkalmaz minden megadott tömb elemére
- array_merge_recursive — rekurzívan egyesít két vagy több tömböt
- array_merge — Egyesít egy vagy több tömböt
- array_multisort — Egyszerre több tömböt vagy egy többdimenziós tömböt rendez
- array_pad — Adott méretűre bővít és tölt fel egy tömböt
- array_pop — Kivesz egy elemet a tömb végéről
- array_product — Calculate the product of values in an array
- array_push — egy vagy több elemet illeszt a tömb végére
- array_rand — véletlenszerűen egy vagy több elemet hoz elő a tömbből
- array_reduce — elemi értékre csökkenti a tömböt tetszőleges függvény meghívásával
- array_reverse — tömb fordított sorrendű elemeivel tér vissza
- array_search — Adott elemet keres a tömbben és az indexével tér vissza
- array_shift — Kiforgatja a tömb első elemét
- array_slice — A tömb egy részével tér vissza
- array_splice — Lecseréli a tömb egy részét
- array_sum — A tömbbeli elemek összegét számolja ki
- array_udiff_assoc — Computes the difference of arrays with additional index check, compares data by a callback function
- array_udiff_uassoc — Computes the difference of arrays with additional index check, compares data and indexes by a callback function
- array_udiff — Computes the difference of arrays by using a callback function for data comparison
- array_uintersect_assoc — Computes the intersection of arrays with additional index check, compares data by a callback function
- array_uintersect_uassoc — Computes the intersection of arrays with additional index check, compares data and indexes by a callback functions
- array_uintersect — Computes the intersection of arrays, compares data by a callback function
- array_unique — törli az ismétlődő elemeket
- array_unshift — Beszúr a tömb elejére egy vagy több elemet
- array_values — visszadja az összes tömbben előforduló értéket
- array_walk_recursive — Apply a user function recursively to every member of an array
- array_walk — felhasználói függvényt futtat a tömb minden elemén
- array — Létrehoz egy tömböt
- arsort — Fordított sorrendben rendez egy tömböt megtartva az indextársítást
- asort — Tömb elemeit rendezi megtartva az indextársítást
- compact — Tömbbe tömöríti a változókat és értékeiket
- count — Megszámolja egy tömb elemeit, vagy egy objektum tulajdonságelemeit
- current — visszaadja egy tömb aktuális elemét
- each — visszaadja a tömb pillanatnyilag kijelölt elemét és lépteti a belső mutatót
- end — Az utolsó elemre állítja a tömb belső mutatóját
- extract — tömbből változókat helyez el az aktuális szimbólumtáblába
- in_array — TRUE-val tér vissza, ha létezik az érték a tömbben
- key — asszociatív tömb pillanatnyilag kiválasztott kulcsát adja vissza
- krsort — Kulcsok alapján fordított sorrendbe rendez egy tömböt
- ksort — Kulcsok alapján rendezi a tömböt
- list — értéket rendel a felsorolt változókhoz
- natcasesort — tömböt rendez a "natural order" (természetes sorrend) algoritmus alapján kis-nagybetűk figyelembevétele nélkül
- natsort — tömböt rendez a "natural order" (természetes sorrend) algoritmus alapján
- next — előre mozgatja a tömb belső mutatóját
- pos — A current függvény álneve
- prev — visszlépteti a tömb belső mutatóját
- range — egy tartományt lefedő tömböt készít
- reset — a tömb belső mutatóját az első elemére állítja
- rsort — Fordított sorrendben rendez egy tömböt
- shuffle — összekeveri a tömb elemeit
- sizeof — A count függvény álneve
- sort — tömböt rendez
- uasort — tömböt rendez egy felhasználó összehasonlító függvénnyel megtartva az indextársítást
- uksort — tömböt rendez kulcsai alapján egy felhasználó összehasonlító függvénnyel
- usort — tömböt rendez elemértékei alapján egy felhasználó összehasonlító függvénnyel
Tömbök
06-Apr-2008 10:38
29-Mar-2008 03:28
This is the shorter way to flatten a array:
<?php
function array_flatten($a) {
foreach($a as $k=>$v) $a[$k]=(array)$v;
return call_user_func_array(array_merge,$a);
}
?>
17-Mar-2008 12:17
I see a lot of people here writing complex functions to convert an array to a string, for use with Javascript or other things (possibly even databases, which would be bad).
For Javascript, the most efficient way would be JSON (http://www.php.net/json_encode). For normal use, serialize() (http://www.php.net/serialize) is your friend.
06-Mar-2008 09:03
@margol:
<?php
$tuple_array = array(array('key1' => 'val1'), array('key2' => 'val2'));
list($key, $val) = each(array_pop($tuple_array));
?>
But, why not use a two element array instead of a single-element associative array?
<?php
$tuple_array = array(array('key1', 'val1'), array('key2','val2'));
list($key,$val) = array_pop($tuple_array);
?>
04-Mar-2008 04:45
More intuitive tuple support would be nice :)
But for those scratching their heads, like I did, to extract a tuple from an array of tuples, do something like:
$tuple = array_pop($tuple_array);
$key = key($tuple);
$val = $tuple[$key];
28-Feb-2008 02:26
Here is how you refresh the expiration time for multiple cookies:
// get the cookie names
$keys=array_keys($_COOKIE);
// loop through all the cookies and update the exp. time
for ($i=0; $i<count($_COOKIE);$i++)
setcookie( $keys[$i], $_COOKIE[$keys[$i]], time()+3600);
you can use this in authentication validate file to keep the session up.
14-Feb-2008 01:35
This function takes an array, a key and a value. If the key is not an array, it acts just like $array[$key] =& $value; If the key is an array, it recurses in the array, creating nested arrays as necessary.
Example:
$array = array('A' => array('B' => 'phi'));
$key = array('A', 'Z');
$value = 'gamma';
arraySet($array, $key, $value);
$array should now be:
array('A' => array('B' => 'phi', 'C' => 'gamma'));
This is useful for constructing nested arrays from sets of filesystem paths (e.g. 'A/B/C') or structured variable names (e.g. 'A.B.C' or 'A[B][C]')
Example:
arraySet($array, preg_split('/\//', $path, -1, PREG_SPLIT_NO_EMPTY), $value);
function arraySet(array &$array, $key, &$value)
{
if (is_array($key)) {
$keyComponent = array_shift($key);
if (empty($key)) {
$array[$keyComponent] =& $value;
return;
}
if (!is_array($array[$keyComponent])) {
$array[$keyComponent] = array();
}
PHP_CodeSniffer_arraySet($array[$keyComponent], $key, $value);
return;
}
$array[$key] =& $value;
}
13-Feb-2008 10:22
I haven't completely figured out when or why an array gets referenced or copied, but it gave me quite the headache..
So i wrote a function which recursively copies an array while preserving keys and also clones objects if encountered
<?php
/**
* make a recursive copy of an array
*
* @param array $aSource
* @return array copy of source array
*/
function array_copy ($aSource) {
// check if input is really an array
if (!is_array($aSource)) {
throw new Exception("Input is not an Array");
}
// initialize return array
$aRetAr = array();
// get array keys
$aKeys = array_keys($aSource);
// get array values
$aVals = array_values($aSource);
// loop through array and assign keys+values to new return array
for ($x=0;$x<count($aKeys);$x++) {
// clone if object
if (is_object($aVals[$x])) {
$aRetAr[$aKeys[$x]]=clone $aVals[$x];
// recursively add array
} elseif (is_array($aVals[$x])) {
$aRetAr[$aKeys[$x]]=array_copy ($aVals[$x]);
// assign just a plain scalar value
} else {
$aRetAr[$aKeys[$x]]=$aVals[$x];
}
}
return $aRetAr;
}
?>
I hope i can save someone else's aspirine with this ;)
06-Feb-2008 01:26
Here's a function I wrote to combine the values in an array in all different ways, and which returns a two-dimensional array as a byref result.
E.g.
if called:
comb(array(1, 2, 3), $r);
then $r would be:
1 2 3
1 3 2
2 1 3
2 3 1
3 1 2
3 2 1
<?php
function comb($arr, &$rarr, $vtemp = array()){
foreach($arr as $key => $value){
$vtemp2 = $vtemp;
$vtemp2[] = $value;
$atemp = $arr;
unset($atemp[$key]);
if(count($atemp) > 0){
comb($atemp, $rarr, $vtemp2);
} else {
$t = array();
foreach($vtemp2 as $val){
$t[] = $val;
}
$rarr[] = $t;
}
}
}
?>
02-Feb-2008 04:12
Here are two more functions handling string2array and access array by string. It's useful if you want to access an array in xpath-style, such as parse_ini_file return values with $process_sections = TRUE.
<?php
function createArrayByString($string, $separator, $value = NULL)
{
if (strlen($string) > 0) {
$splitter = explode($separator, $string);
$index = array_shift($splitter); // get first element
$function = __FUNCTION__;
return array($index => $function(implode($separator, $splitter), $separator, $value));
}
return $value;
}
function accessArrayByString($array, $string, $separator, $default = NULL)
{
if (!is_array($array)) {
return empty($string) ? $array : $default;
}
@list ($key, $rest) = explode($separator, $string, 2); // @ needed for last access
$function = __FUNCTION__;
return array_key_exists($key, $array)
? $function($array[$key], $rest, $separator, $default)
: $default;
}
$string = "one.two.three.four";
$separator = ".";
$array = createArrayByString($string, $separator, "standard value");
$return = accessArrayByString($array, $string, $separator, "element not found");
var_dump($array); // should return array("one" => array("two" => array("three" => array("four" => "standard value"))))
var_dump($return); // should return "standard value";
?>
change the function name to what ever you want, the recursive call uses __FUNCTION__ for re-call.
30-Jan-2008 05:09
I've created a class which is comparable to a Vector in C++;
<?php
class Vector {
public $nb_elements;
public $liste;
public function Vector() {
$this->liste = array ();
$this->nb_elements = count($this->liste);
}
public function push_back($valeur) {
if (!empty ($valeur)) {
$this->liste[] = $valeur;
$this->nb_elements = count($this->liste);
return true;
} else {
return false;
}
}
public function insert_at($indice, $valeur) {
if ($indice > 0 && $indice < $this->nb_elements) {
for ($i = $this->nb_elements; $i != $indice; $i--) {
$this->liste[$i] = $this->liste[$i -1];
}
$this->liste[$indice] = $valeur;
$this->nb_elements = count($this->liste);
return true;
} else {
return false;
}
}
public function remove_at($indice) {
if ($indice > 0 && $indice < $this->nb_elements) {
for ($i = $indice; $i != $this->nb_elements - 1; $i++) {
$this->liste[$i] = $this->liste[$i +1];
}
array_pop($this->liste);
$this->nb_elements = count($this->liste);
return true;
} else {
return false;
}
}
public function pop() {
$value = array_pop($this->liste);
$this->nb_elements = count($this->liste);
return $value;
}
public function shift() {
$value = array_shift($this->liste);
$this->nb_elements = count($this->liste);
return true;
}
}
?>
25-Jan-2008 03:37
function array_flatten($a){ //flattens multi-dim arrays (distroys keys)
$ab = array(); if(!is_array($a)) return $ab;
foreach($a as $value){
if(is_array($value)){
$ab = array_merge($ab,array_flatten($value));
}else{
array_push($ab,$value);
}
}
return $ab;
}
25-Jan-2008 05:00
A usefull function that returns a flat array.
I use it in a template system. Let the user pass a multidimensional array. Convert it using my function. Then use
<?php
$array = flatten($array,'','{$','}','->');
echo str_replace(array_keys($array),array_values($array),$template)
/**
* Flattens out an multidimension array
* Using the last parameters you can define the new key based on the old path.
* @param array $array A multidimension array
* @param string $prefix Internal perfix parameter - leave empty.
* @param string $start_string What string should start the final array key?
* @param string $end_string What string should end the final array key?
* @param string $seperator The string that should seperate the piecies in final array key path
* @return array Returns the flat array
*/
function flatten($array, $start_string= '{$',$end_string= '}',$seperator='->',$prefix="") {
$return = array();
foreach($array as $key=>$value) {
if (is_array($value)) {
$return = array_merge($return, Parser_method_replace::flatten($value, $prefix.$key.$seperator,$start_string,$end_string,$seperator));
} else
$return [$start_string.$prefix.$key.$end_string] = $value;
}
return $return;
}
}
?>
Example:
$template = 'My string with replacement {$test->subkey}';
{$test->subkey} will get replaced with $array['test']['subkey']
02-Jan-2008 06:53
if some one will need to convert array to php code use this function:
DEFINE('OFFSET_DELIMETER', "\t");
function array2php($array, $offset = OFFSET_DELIMETER) {
$text = '';
foreach($array as $k => $v) {
if (is_array($v)) {
$text .= "{$offset}'{$k}' => array(\n".array2php($v, $offset.OFFSET_DELIMETER)."$offset)";
} else {
$text .= "{$offset}'{$k}' => ".(is_string($v)? "'$v'": $v);
}
$text .= ",\n";
}
if ($len = strlen($text)) $text[$len - 2] = " ";
return $text;
}
17-Oct-2007 07:10
Regarding cyberchrist at futura dot net's function. It makes an unnecessary array_merge(); the elements of $b that are merged with those of $a are immediately removed again by the array_diff(). The "limiting to known values" is entirely unnecessary, in other words: arrays already only contain "known values".
Also, the description and function only address the issue of whether $a is a subset of $b, not whether it is a proper subset. For $a to be a proper subset of $b, it must also be the case that $b is not a subset of $a.
Taking those points into account (and a personal aesthetic dislike of "if(test) return true; else return false;" gives:
<?php
function is_subset($a, $b)
{
return count(array_diff($a,$b))==0;
}
function is_proper_subset($a, $b)
{
return is_subset($a, $b) && !is_subset($b, $a);
}
?>
15-Oct-2007 09:33
Lately, dealing with databases, I've been finding myself needing to know if one array, $a, is a proper subset of $b.
Mathematically, this is asking (in set theory) [excuse the use of u and n instead of proper Unicode):
( A u B ) n ( ~ B )
What this does is it first limits to known values, then looks for anything outside of B but in the union of A and B (which would be those things in A which are not also in B).
If any value exists in this set, then A is NOT a proper subset of B, because a value exists in A but not in B. For A to be a proper subset, all values in A must be in B.
I'm sure this could easily be done any number of ways but this seems to work for me. It's not got a lot of error detection such as sterilizing inputs or checking input types.
// bool array_subset( array, array )
// Returns true if $a is a proper subset of $b, returns false otherwise.
function array_subset( $a, $b )
{
if( count( array_diff( array_merge($a,$b), $b)) == 0 )
return true;
else
return false;
}
30-Aug-2007 02:56
<?php
/**
* converts a multidimensional array to a flat array
*
* trying to keep the original names of the keys
* if repeated keys are found a hash will be added to the
* keys trying to keep as much as possible of the original
* key context
*
* september 30 2007
*
* PHP version 5
*
* @license GPL
*
*/
$array = array ( 0 => array ( 0 => 1, 1 => 2, 2 => array ( 0 => 3, 1 => 4, 2 =>
array ( 0 => 5, 1 => 6, 2 => array ( 0 => 7, 1 => 8,),),), 3 => array (
0 => array ( 0 => 9, 1 => 10, 2 => array ( 0 => 11, 1 => 12,
2 => array ( 0 => 13, 1 => 14, 2 => array ( 0 => 15, 1 => 16,),),),),
1 => array ( 0 => 17, 1 => 18,),),), 1 => array ( 0 => 19, 1 => 20,),
2 => array ( 0 => array ( 0 => 21, 1 => 22, 2 => array ( 0 => 23, 1 => 24,
2 => array ( 0 => 25, 1 => 26, 2 => array ( 0 => 27, 1 => 28,),),),),
1 => array ( 0 => 29, 1 => 30,),),);
/**
* transforms a multidimensional array to a flat array
*
* the parameter is referenced
* so no returning value is needed
* @param array $array the multidimensional array to flat
* @return void
*/
function array_flatten(&$array)
{
function has_arrays($array)
{
foreach ($array as $item) {
if (is_array($item)) {
return true;
}
}
return false;
}
function copy_array(&$array, $array_key)
{
$array2 = $array[$array_key];
unset($array[$array_key]);
foreach ($array2 as $subkey => $subvalue) {
if (array_key_exists($subkey, $array)) {
$array[generate_unique_key($subkey)] = $subvalue;
} else {
$array[$subkey] = $subvalue;
}
}
}
function generate_unique_key($key)
{
if (strlen($key)>8) {
$key = $key[0] . $key[1] . $key[2];
}
$id = $key . '_';
$uid = uniqid();
$len = strlen($uid);
$max = (9 - strlen($key));
for ($c = $len; ; $c --) {
$id .= $uid[$c];
if ($c == ($len - $max)) {
break;
}
}
return $id;
}
function get_array_indexes($array)
{
$ret_array = array();
foreach ($array as $key => $value) {
if (is_array($value)) {
$ret_array[] = $key;
}
}
return $ret_array;
}
while(has_arrays($array)) {
foreach (get_array_indexes($array) as $key) {
copy_array($array, $key);
}
}
}
array_flatten($array);
array_multisort($array);
var_export($array);
/**
* OUTPUT
*
* array (
* 0 => 1,
* '1_403767b6' => 2,
* '0_793767b6' => 3,
* '1_8a3767b6' => 4,
* '0_454767b6' => 5,
* '1_564767b6' => 6,
* '0_035767b6' => 7,
* '1_345767b6' => 8,
* '0_e74767b6' => 9,
* '1_f84767b6' => 10,
* '0_855767b6' => 11,
* '1_a65767b6' => 12,
* '0_4e5767b6' => 13,
* '1_6f5767b6' => 14,
* '0_566767b6' => 15,
* '1_876767b6' => 16,
* '0_5b4767b6' => 17,
* '1_6c4767b6' => 18,
* '0_d43767b6' => 19,
* 1 => 20,
* '0_4e3767b6' => 21,
* '1_5f3767b6' => 22,
* '0_ad4767b6' => 23,
* '1_ce4767b6' => 24,
* '0_485767b6' => 25,
* '1_695767b6' => 26,
* '0_116767b6' => 27,
* '1_426767b6' => 28,
* '0_814767b6' => 29,
* '1_924767b6' => 30,
* )
*/
?>
31-Jul-2007 02:27
to 2g4wx3:
i think better way for this is using JSON, if you have such module in your PHP. See json.org.
to convert JS array to JSON string: arr.toJSONString();
to convert JSON string to PHP array: json_decode($jsonString);
You can also stringify objects, numbers, etc.
19-Jul-2007 05:16
I needed a function to convert a php array into a javascript array.
No problem i found it on "the net".
But the function i found wasn't good enough, instead of return a string with javascript-array it echoed directly everything.
I wanted to write the string to a file, when calling the function out of my function libary.
Secondly, there where minor "bugs" in the script, when you're original array contained characters like line breaks(\r\n,..), or quotes('), it would hack up the javascript array
Sow, i changed the function and fixed the bug.
<?php
//SUPER COOL : http://www.communitymx.com/content/article.cfm?page=3&cid=7CD16
//Checkout: REVERSE: http://www.hscripts.com/tutorials/php/jsArrayToPHP.php
//Convert a PHP array to a JavaScript one (rev. 4)
//Changlog by g4wx3: echo replaced by $output, added function output
function output($string) //make javascript ready
{
$string = str_replace( array( '\\' , '\'' ), array('\\\\', '\\\'') , $string); //-> for javascript array
$string = str_replace( array("\r\n", "\r", "\n") , '<br>' , $string); //nl2br
return $string;
}
function arrayToJS4($array, $baseName ) {
//Write out the initial array definition
//v4 echo ($baseName . " = new Array(); \r\n ");
$output = $baseName . " = new Array(); \r\n ";
//Reset the array loop pointer
reset ($array);
//Use list() and each() to loop over each key/value
//pair of the array
while (list($key, $value) = each($array)) {
if (is_numeric($key)) {
//A numeric key, so output as usual
$outKey = "[" . $key . "]";
} else {
//A string key, so output as a string
$outKey = "['" . $key . "']";
}
if (is_array($value)) {
//The value is another array, so simply call
//another instance of this function to handle it
$output .= arrayToJS4($value, $baseName . $outKey);
} else {
//Output the key declaration
//v4 echo ($baseName . $outKey . " = ");
$output .= $baseName . $outKey . " = ";
//Now output the value
if (is_string($value)) {
//Output as a string, as we did before
//v4 echo ("'" . output($value) . "'; \r\n ");
$output .= "'" . output($value) . "'; \r\n ";
} else if ($value === false) {
//Explicitly output false
//v4 echo ("false; \r\n");
$output .= "false; \r\n";
} else if ($value === NULL) {
//Explicitly output null
//v4 echo ("null; \r\n");
$output .= "null; \r\n";
} else if ($value === true) {
//Explicitly output true
//v4 echo ("true; \r\n");
$output .= "true; \r\n";
} else {
//Output the value directly otherwise
//v4 echo ($value . "; \r\n");
$output .= $value . "; \r\n";
}
}
}
return $output;
}
?>
You can use this for printing $_GET array, for example
15-Jun-2007 06:15
heres a function from http://www.linksback.org Feedback welcome, of course! Public domain, yadda yadda.
function mySort(&$array,$key) {
if (!is_array($array) || count($array) == 0) return true;
$assocSortCompare = '$a = $a["'.$key.'"]; $b = $b["'.$key.'"];';
if (is_numeric($array[0][$key])) {
$assocSortCompare.= ' return ($a == $b) ? 0 : (($a < $b) ? -1 : 1);';
} else {
$assocSortCompare.= ' return strcmp($a,$b);';
}
$assocSortCompare = create_function('$a,$b',$assocSortCompare);
return usort($array,$assocSortCompare);
}
11-Jun-2007 12:06
Bugs happen, but how can people post functions that WON'T EVEN COMPILE! I truly detest finding a cool code snippet or function and then having to debug them. Sorry for the rant, but I have experienced this scenario a number of times. TEST YOUR CODE, THEN POST!
Here is a revised and corrected previously posted function ArrayDepth, which had 3 bugs and yes, would not compile.
function ArrayDepth($Array,$DepthCount=-1) {
// Find maximum depth of an array
// Usage: int ArrayDepth( array $array )
// returns integer with max depth
// if Array is a string or an empty array it will return 0
$DepthArray=array(0);
$DepthCount++;
$Depth = 0;
if (is_array($Array))
foreach ($Array as $Key => $Value) {
$DepthArray[]=ArrayDepth($Value,$DepthCount);
}
else
return $DepthCount;
return max($DepthCount,max($DepthArray));
}
29-May-2007 05:57
<?php
/* This function allow you to transform a multidimensional array
in a simple monodimensional array.
Usage: array_walk($oldarray, 'flatten_array', &$newarray);
For example, this code below shows to you:
Array
(
[1] => Array
(
[0] => 1
[1] => 2
)
[2] => Array
(
[0] => 3
[1] => 4
)
)
Array
(
[0] => 1
[1] => 2
[2] => 3
[3] => 4
)
*/
function flatten_array($value, $key, &$array) {
if (!is_array($value))
array_push($array,$value);
else
array_walk($value, 'flatten_array', &$array);
}
$oldarray = array(
1 => array(1,2),
2 => array(3,4)
);
$newarray = array();
array_walk($oldarray, 'flatten_array', &$newarray);
echo "<pre>";
print_r($oldarray);
print_r($newarray);
echo "</pre>";
?>
17-Apr-2007 04:13
A modernized version of the flatten_array() functies written by
davidj at boundlessgallery dot DISLIKESPAM dot com
on 02-Apr-2004 03:10
This function is able to work with associative arrays
<?php
