PHP 基礎知識-數組

PHP 的數組主要分為:

  • 索引數組?- 帶有數字索引的數組
  • 關聯數組?- 帶有指定鍵的數組
  • 多維數組?- 包含一個或多個數組的數組 ? ? ? ??
索引數組:
有兩種創建索引數組的方法:

? 索引是自動分配的(索引從 0 開始):

? 第一種:

$cars=array("Volvo","BMW","SAAB");
第二種:
$cars[0]="Volvo";
$cars[1]="BMW";
$cars[2]="SAAB";
獲取數組長度的函數:
count() 函數用于返回數組的長度(元素數):
示例:
<?php
$cars=array("Volvo","BMW","SAAB");
echo count($cars);
?>

遍歷索引數組

如需遍歷并輸出索引數組的所有值,您可以使用 for 循環,就像這樣:

<?php
$cars=array("Volvo","BMW","SAAB");
$arrlength=count($cars);for($x=0;$x<$arrlength;$x++) {
echo $cars[$x];
echo "<br>";
}
?>

PHP 關聯數組

關聯數組是使用您分配給數組的指定鍵的數組。

有兩種創建關聯數組的方法:

第一種:

$age=array("Peter"=>"35","Ben"=>"37","Joe"=>"43");
第二種:
$age['Peter']="35";
$age['Ben']="37";
$age['Joe']="43";
運行示例:
<?php
$age=array("Bill"=>"35","Steve"=>"37","Peter"=>"43");
echo "Peter is " . $age['Peter'] . " years old.";
?>

遍歷關聯數組

如需遍歷并輸出關聯數組的所有值,您可以使用 foreach 循環,就像這樣:

實例:

<?php
$age=array("Bill"=>"35","Steve"=>"37","Peter"=>"43");foreach($age as $x=>$x_value) {
echo "Key=" . $x . ", Value=" . $x_value;
echo "<br>";
}
?>
//定義數組和向數組中增加一個新的索引數組元素
<?php
$array = array("a", "b","c"); //定義數組
$array[] = "Simon"; //增加一個新的數組元素
print_r($array); //輸出數組
?>
//定義一個新的索引數組并向數組得中指定位置中添加一個新的元素
<?php
$array = array("a", "b","c"); //定義數組
$array[9] = "Simon"; //增加一個新的數組元素
print_r($array); //輸出數組
?>
<?php
//創建一個簡單的數組
$array = array(0=>1, 1=>2, 2=>3, 3=>4, 6=>5);
print_r($array);
//現在把數組中鍵為2的值更新為100
$array[2] = 100;
print_r($array);
//現在添加一個鍵
$array["X"] = 50;
print_r($array);
//現在刪除所有鍵,但保持數組本身的結構
foreach($array as $i => $value)
{
unset($array[$i]);
}
print_r($array);
//再添加一個鍵
$array[] = 25;
print_r($array);
//使用array_values函數進行重新索引
$array = array_values($array);
$array[] = 13;
print_r($array);
?>

?

一、數組操作的基本函數
數組的鍵名和值
array_values($arr);  獲得數組的值
array_keys($arr);  獲得數組的鍵名
array_flip($arr);  數組中的值與鍵名互換(如果有重復前面的會被后面的覆蓋)
in_array("apple",$arr);  在數組中檢索apple
array_search("apple",$arr);  在數組中檢索apple ,如果存在返回鍵名
array_key_exists("apple",$arr);  檢索給定的鍵名是否存在數組中
isset($arr[apple]):   檢索給定的鍵名是否存在數組中數組的內部指針
current($arr);  返回數組中的當前單元
pos($arr);  返回數組中的當前單元
key($arr);  返回數組中當前單元的鍵名
prev($arr);  將數組中的內部指針倒回一位
next($arr);  將數組中的內部指針向前移動一位
end($arr);  將數組中的內部指針指向最后一個單元
reset($arr;  將數組中的內部指針指向第一個單元
each($arr);  將返回數組當前元素的一個鍵名/值的構造數組,并使數組指針向前移動一位
list($key,$value)=each($arr);  獲得數組當前元素的鍵名和值數組和變量之間的轉換
extract($arr);用于把數組中的元素轉換成變量導入到當前文件中,鍵名當作變量名,值作為變量值
注:(第二個參數很重要,可以看手冊使用)使用方法 echo $a;
compact(var1,var2,var3);用給定的變量名創建一個數組二、數組的分段和填充
數組的分段
array_slice($arr,0,3);  可以將數組中的一段取出,此函數忽略鍵名
array_splice($arr,0,3,array("black","maroon"));  可以將數組中的一段取出,與上個函數不同在于返回的序列從原數組中刪除分割多個數組
array_chunk($arr,3,TRUE);  可以將一個數組分割成多個,TRUE為保留原數組的鍵名數組的填充
array_pad($arr,5,'x');  將一個數組填補到制定長度三、數組與棧
array_push($arr,"apple","pear");  將一個或多個元素壓入數組棧的末尾(入棧),返回入棧元素的個數
array_pop($arr);  將數組棧的最后一個元素彈出(出棧)四、數組與列隊
array_shift($arr);數組中的第一個元素移出并作為結果返回(數組長度減1,其他元素向前移動一位,數字鍵名改為從零技術,文字鍵名不變)
array_unshift($arr,"a",array(1,2));在數組的開頭插入一個或多個元素五、回調函數
array_walk($arr,'function','words');  使用用戶函數對數組中的每個成員進行處理(第三個參數傳遞給回調函數function)
array_mpa("function",$arr1,$arr2);  可以處理多個數組(當使用兩個或更多數組時,他們的長度應該相同)
array_filter($arr,"function");  使用回調函數過濾數組中的每個元素,如果回調函數為TRUE,數組的當前元素會被包含在返回的結果數組中,數組的鍵名保留不變
array_reduce($arr,"function","*");  轉化為單值函數(*為數組的第一個值)六、數組的排序
通過元素值對數組排序
sort($arr);  由小到大的順序排序(第二個參數為按什么方式排序)忽略鍵名的數組排序
rsort($arr);  由大到小的順序排序(第二個參數為按什么方式排序)忽略鍵名的數組排序
usort($arr,"function");  使用用戶自定義的比較函數對數組中的值進行排序(function中有兩個參數,0表示相等,正數表示第一個大于第二個,負數表示第一個小于第二個)忽略鍵名的數組排序
asort($arr);  由小到大的順序排序(第二個參數為按什么方式排序)保留鍵名的數組排序
arsort($arr);  由大到小的順序排序(第二個參數為按什么方式排序)保留鍵名的數組排序
uasort($arr,"function");  使用用戶自定義的比較函數對數組中的值進行排序(function中有兩個參數,0表示相等,正數表示第一個大于第二個,負數表示第一個小于第二個)保留鍵名的數組排序通過鍵名對數組排序
ksort($arr);  按照鍵名正序排序
krsort($arr);  按照鍵名逆序排序
uksort($arr,"function");  使用用戶自定義的比較函數對數組中的鍵名進行排序(function中有兩個參數,0表示相等,正數表示第一個大于第二個,負數表示第一個小于第二個)自然排序法排序
natsort($arr);  自然排序(忽略鍵名)
natcasesort($arr);  自然排序(忽略大小寫,忽略鍵名)七、數組的計算
數組元素的求和
array_sum($arr);  對數組內部的所有元素做求和運算數組的合并
array_merge($arr1,$arr2);  合并兩個或多個數組(相同的字符串鍵名,后面的覆蓋前面的,相同的數字鍵名,后面的不會做覆蓋操作,而是附加到后面)
“+”$arr1+$arr2;  對于相同的鍵名只保留后一個
array_merge_recursive($arr1,$arr2);   遞歸合并操作,如果數組中有相同的字符串鍵名,這些值將被合并到一個數組中去。如果一個值本身是一個數組,將按照相應的鍵名把它合并為另一個數組。當數組 具有相同的數組鍵名時,后一個值將不會覆蓋原來的值,而是附加到后面數組的差集
array_diff($arr1,$arr2);  返回差集結果數組
array_diff_assoc($arr1,$arr2,$arr3);  返回差集結果數組,鍵名也做比較數組的交集
array_intersect($arr1,$arr2);  返回交集結果數組
array_intersect_assoc($arr1,$arr2);  返回交集結果數組,鍵名也做比較八、其他的數組函數
range(0,12);  創建一個包含指定范圍單元的數組
array_unique($arr);  移除數組中重復的值,新的數組中會保留原始的鍵名
array_reverse($arr,TRUE);  返回一個單元順序與原數組相反的數組,如果第二個參數為TRUE保留原來的鍵名
//srand((float)microtime()*10000000);   隨機種子觸發器
array_rand($arr,2);  從數組中隨機取出一個或 多個元素
shuffle($arr);  將數組的順序打亂

?

轉載于:https://www.cnblogs.com/Lance--blog/p/5849634.html

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/256411.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/256411.shtml
英文地址,請注明出處:http://en.pswp.cn/news/256411.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

打開word2016總是出現很抱歉,此功能看似中斷需要修復。。問題解決辦法

第一步 打開運行窗口&#xff0c;在電腦桌面左下角有個圓圈點擊進去&#xff0c;輸入regedit&#xff0c;即可進入。 第二步 打開HKEY_CURRENT_USER中的SOFTWARE 第三步 找到HKEY_CURRENT_USER\SOFTWARE\Microsoft\Office\16.0\Word\Options項如圖紅色箭頭標示。然后點擊O…

機器學習——人工神經網絡之多層神經網絡(多層與三層)

目錄 一、多層神經網絡 1、多層神經網絡數學模型 2、數學模型中的非線性函數fai 1&#xff09;非線性函數fai存在的意義 2&#xff09;非線性函數fai具體是什么&#xff1f; 3、多層神經網絡與單層神經網絡的區別與改進 1&#xff09;單層神經網絡數學模型 2&#xff0…

noip2012-day2-t2

【問題描述】 在大學期間&#xff0c;經常需要租借教室。大到院系舉辦活動&#xff0c;小到學習小組自習討論&#xff0c;都需要向學校申請借教室。教室的大小功能不同&#xff0c;借教室人的身份不同&#xff0c;借教室的手續也不一樣。 面對海量租借教室的信息&#xff0c;我…

機器學習——人工神經網絡之后向傳播算法(BP算法)

目錄 一、后向傳播算法的本質——梯度下降法求局部極值 1、w迭代公式的合理性

獲取視圖的寬高

1 view.measure(RelativeLayout.LayoutParams.WRAP_CONTENT, RelativeLayout.LayoutParams.WRAP_CONTENT); 2 int width view.getMeasuredWidth(); 3 int height view.getMeasuredHeight(); 轉載于:https://www.cnblogs.com/cmgrass/p/4978222.html

排序算法02--冒泡排序

思路&#xff1a;冒泡排序 就是把大的數一個個沉到下面&#xff0c;當然也可以是把小的數一個個浮到上面。 在最外層需要比較n-1次&#xff0c;因為n-1個大的數被沉到了下面&#xff0c;剩下一個自然就是最小的數了。 在這n-1次的里層&#xff0c;還需要亮亮相互比較&#xff0…

機器學習——人工神經網絡之參數設置(BP算法)

目錄 一、復習(BP算法) 二、訓練模型的建議 三、參數設置內容 1、隨機梯度下降(SGD)

關于▲的各種交點

對于△ABC證明&#xff1a; ①三角形的三條中線交于一點&#xff1a; 等腰三角形&#xff1a;作中線BD、CE與AC、AB交于D、E&#xff0c;相交于O&#xff0c;連接AO并延長交BC于F&#xff1b; 證△ABD全等于△ACE&#xff0c;再證△EBO全等于△D…

javaScript獲取url中的參數

var urlTools {//獲取RUL參數值getUrlParam: function(name) { /*?videoIdidentification */var params decodeURI(window.location.search); /* 截取&#xff1f;號后面的部分 index.html?actdoctor,截取后的字符串就是?actdoctor */var reg …

機器學習——支持向量機SVMpython實現

一、SVM理論 可見以下文章&#xff1a; 《機器學習——支持向量機SVM之線性模型》 《機器學習——支持向量機SVM之非線性模型低維到高維映射》 《機器學習——支持向量機SVM之非線性模型原問題與對偶問題》 《機器學習——支持向量機SVM之非線性模型原問題轉化為對偶問題》…

瑣碎易錯點

1.font-size 設置的是字體的高 2.瀏覽器內核&#xff1a; 主流瀏覽器   內核 IE       trident Firfox     Gecko Chorme    Webkit&#xff08;原來&#xff09;/blink&#xff08;現在&#xff09; Safari     Webkit&#xff08;蘋果公司獨立研發的&a…

Python安裝Jupyter Notebook配置使用教程

原文見&#xff1a;https://blog.csdn.net/qq_27825451/article/details/84427269 一、什么是jupyter 1、簡介&#xff1a; jupyter notebook是一種 Web 應用&#xff0c;能讓用戶將說明文本、數學方程、代碼和可視化內容全部組合到一個易于共享的文檔中。它可以直接在代碼旁…

ExtJS4.2學習(10)分組表格控件--GroupingGrid(轉)

鳴謝網址&#xff1a;http://www.shuyangyang.com.cn/jishuliangongfang/qianduanjishu/2013-11-17/179.html --------------------------------------------------------------------------------------------- 分組表格控件在我們的開發中經常被用到&#xff0c;GroupingGrid…

九個Console命令,讓js調試更簡單

一、顯示信息的命令 1: <!DOCTYPE html>2: <html>3: <head>4: <title>常用console命令</title>5: <meta http-equiv"Content-Type" content"text/html; charsetutf-8" />6: </head>7: <body>8: …

numpy——axis

size()和max()中的含義 以前我理解axis0代表行&#xff0c;axis1代表列&#xff1b; 但是這種含義在函數size()和max()中恰恰相反&#xff1b; 其實不是這樣的&#xff0c;我們回到單詞axis本身&#xff0c;它的意思是“軸”&#xff0c;沒錯軸就是代表一個方向&#xff0c;像…

Android ListView幾個重要屬性

1、transciptMode屬性&#xff0c;需要用ListView或者其它顯示大量Items的控件實時跟蹤或者查看信息&#xff0c;并且希望最新的條目可以自動滾動到可視范圍內。通過設置的控件transcriptMode屬性可以將Android平臺的控件&#xff08;支持ScrollBar&#xff09;自動滑動到最底部…

Halcon例程(基于GMM模型的分類)詳解 —— classify_citrus_fruits.hdev

一、例程簡介 該例程比較有代表性&#xff0c;屬于Halcon里的分類方法之一&#xff0c;直接調用Halcon封裝好的GMM分類器&#xff08;高斯混合模型&#xff09;對橘子和檸檬進行分類。GMM屬于概率分類方法&#xff0c;屬于P(Y|X)&#xff0c;通過對樣本的概率密度分布進行估計…

正則表達式匹配不包含特定字符串解決匹配溢出問題

匹配溢出問題在正則表達式當中算是比較常見的問題&#xff0c;它常常導致我們匹配結果莫名其妙的出錯&#xff0c;本文專門為你講解如何通過匹配不包含特定字符串的方法來解決這類問題。 那么&#xff0c;什么是匹配溢出呢&#xff1f; 下面我們來看個例子&#xff1a; 源文本&…

numpy——mgrid

x1,x2 np.mgrid(x1min:x1max:num1j,x2min:x2max:num2j)x1返回的是x1min到x1max間均勻分成num1個數&#xff0c;進行橫向擴展為方陣 x2返回的是x2min到x2max間均勻分成num2個數&#xff0c;進行縱向擴展為方陣 Examples -------- >>> np.mgrid[0:5,0:5] array([[[0,…

Halcon例程(基于3D形狀匹配識別方法)詳解 —— create_shape_model_3d_lowest_model_level.hdev

一、例程簡介 最近在研究3D識別方面的東西&#xff0c;查了不少資料&#xff0c;發現halcon里有不少關于三維物體識別的例程&#xff0c;這里對其中一個做出詳解。該例程是基于三維匹配方法的&#xff0c;因為有三維模型SM3&#xff0c;所以不需要自己創建&#xff1b;另因為例…