A. php 怎麼樣遍歷
第一、foreach()
foreach()是一個用來遍歷數組中數據的最簡單有效的方法。
<?php
$urls= array('aaa','bbb','ccc','ddd');
foreach ($urls as $url){
echo "This Site url is $url! <br />";
}
?>
顯示結果:
This Site url is aaa
This Site url is bbb
This Site url is ccc
This Site url is ddd
第二、while() 和 list(),each()配合使用。
<?php
$urls= array('aaa','bbb','ccc','ddd');
while(list($key,$val)= each($urls)) {
echo "This Site url is $val.<br />";
}
?>
顯示結果:
?
This Site url is aaa
This Site url is bbb
This Site url is ccc
This Site url is ddd
第三、for()運用for遍歷數組
<?php
$urls= array('aaa','bbb','ccc','ddd');
for ($i= 0;$i< count($urls); $i++){
$str= $urls[$i];
echo "This Site url is $str.<br />";
}
?>
顯示結果:
This Site url is aaa
This Site url is bbb
This Site url is ccc
This Site url is ddd
這幾種遍歷數組的方法哪個更快捷些呢,下面做個簡單的測試就明白了
=========== 下面來測試三種遍歷數組的速度 ===========
一般情況下,遍歷一個數組有三種方法,for、while、foreach。其中最簡單方便的是foreach。下面先讓我們來測試一下共同遍歷一個有50000個下標的一維數組所耗的時間。
<?php
$arr= array();
for($i= 0; $i< 50000; $i++){
$arr[]= $i*rand(1000,9999);
}
function GetRunTime()
{
list($usec,$sec)=explode(" ",microtime());
return ((float)$usec+(float)$sec);
}
######################################
$time_start= GetRunTime();
for($i= 0; $i< count($arr); $i++){
$str= $arr[$i];
}
$time_end= GetRunTime();
$time_used= $time_end- $time_start;
echo 'Used time of for:'.round($time_used, 7).'(s)<br /><br />';
unset($str, $time_start, $time_end, $time_used);
######################################
$time_start= GetRunTime();
while(list($key, $val)= each($arr)){
$str= $val;
}
$time_end= GetRunTime();
$time_used= $time_end- $time_start;
echo 'Used time of while:'.round($time_used, 7).'(s)<br /><br />';
unset($str, $key, $val, $time_start, $time_end, $time_used);
######################################
$time_start= GetRunTime();
foreach($arr as$key=> $val){
$str= $val;
}
$time_end= GetRunTime();
$time_used= $time_end- $time_start;
echo 'Used time of foreach:'.round($time_used, 7).'(s)<br /><br />';
?>
測試結果:
Used time of for:0.0228429(s)
Used time of while:0.0544658(s)
Used time of foreach:0.0085628(s)
結果表明,對於遍歷同樣一個數組,foreach速度最快,最慢的則是while。從原理上來看,foreach是對數組副本進行操作(通過拷貝數組),而while則通過移動數組內部指標進行操作,一般邏輯下認為,while應該比foreach快(因為foreach在開始執行的時候首先把數組復制進去,而while直接移動內部指標。),但結果剛剛相反。原因應該是,foreach是PHP內部實現,而while是通用的循環結構。所以,在通常應用中foreach簡單,而且效率高。在PHP5下,foreach還可以遍歷類的屬性。
希望能夠喜歡。
B. php中如何遍歷Select()查詢到的二位數組的值
親,你好,很高興解答你的問題襲戚
如果你使用的是PHP5.5以上版本,可以直接使用以下代碼就可以獲取到:
$sysIds=array_column($array,'SysId');//$array就是你上面那個數組
如果你用的PHP還是5.5以配搏下的版本,那麼你只能使用foreach循環獲取了:
$sysIds=[];
foreach($arrayas$arr){
foreach($arras$key=>$value){
$sysIds[]=$value;
}
}
希望可以幫到培禪祥你哦!~~
C. 求php foreach遍歷查詢結果顯示到table代碼
<?php
$kkk=array('aaa','aaas'盯渣兄,'bbb');
echo "<table>";
foreach($kkk as $l)
{
echo "<tr><td>".$l."</td>凱襲</tr>";
}
echo "<梁塌/table>";
?>
D. php通過mysql like搜索關鍵詞查詢,所有符合數據遍歷出來
<?php
$host="localhost";
$username="root";
$password="root";
$db="db4"; //庫名
$mysql_table="person"; //表名
//連接資料庫,面向過程
$conn=mysqli_connect($host,$username,$password);
if(!$conn){
echo "資料庫連接失敗";
exit;
}
//選擇所要操作的資料庫
mysqli_select_db($conn,$db);
//設置資料庫編碼格式
mysqli_query($conn,"SET NAMES UTF8");
//編寫sql獲取分頁數據 SELECT * FROM 表名 LIMIT 起始位置,顯示條數
//注意:以下id,name,age,say都是欄位節點名,person是表名,db4是資料庫名,think是指定的關鍵字.
$sql = 'SELECT id, name, age, say
FROM person
WHERE say LIKE "%think%" order by id ASC LIMIT '.($page-1)*$pageSize .",{$pageSize}";
// 節點名 關鍵字 節點名 可指定數量limit後可寫一個指定的數字
//$sql="select * from $mysql_table"
//把sql語句傳送到資料庫
$result=mysqli_query($conn,$sql);
//將數據顯示到table中,並未table設置格式
echo "<div class='content'>";
echo "<table border=1 cellspacing=0 width=30% align=center>";
echo "<tr><td>ID</td><td>NAME</td><td>say</td></tr>";
while ($row = mysqli_fetch_assoc($result)) {
echo "<tr>";
echo "<td>{$row['id']}</td>";
echo "<td>{$row['name']}</td>";
echo "<td>{$row['say']}</td>";
echo "<tr>";
}
echo "</table>";
echo "</div>";
//釋放結果
mysqli_free_result($result);
//關閉資料庫
mysqli_close($conn);
E. php如何將數組遍歷出來的結果相加
方岩擾法1,累加x0dx0a'x0dx0a$sum+=$value;//粗盯旦累加x0dx0a}x0dx0aecho $sum;//顯則春示x0dx0a x0dx0a方法2,直接求x0dx0a
F. php遍歷資料庫問題
首先你要說你用的是什麼資料庫。用最普通的mysql資料庫來說,php自帶了一些操作資料庫的函數。
首知灶簡先你將語句寫入一個變數:
$Query = "select * from A_table";
然後用mysql_query這個函數執行這條語句,並將輸出結果放在一個變數中:
$Result = mysql_query($Query);
這個$Result變數就是一個資源變數,包含了所有符合條件的結果。要將結果處理,需要用另一個函數
mysql_fetch_assoc:
while($Row = mysql_fetch_assoc($Result))
{
//這里$Row就是遍歷了結果的每一行。假設有搭褲個欄位叫A_field,你要把它輸出
echo $Row["A_field"];
//其辯碼他操作類似。
}
G. 發現PHP查詢MYSQL,遍歷結果,會出現2倍數據(資料庫1行數據2列,遍歷輸出4列)
問題出在mysql_fetch_array這一步,此方法的第二個參數表示你要獲取的數組的類型碧鏈
MYSQL_ASSOC 關聯數組,就是鍵名是id,name的
MYSQL_NUM 索引數組,鍵名是數字的
MYSQL_BOTH 以上悔好孫兩種都有
不給第二個參數的襪納話,默認是MYSQL_BOTH,所以就出現了你上面的結果
H. PHP 如何把兩個sql查詢的結果合在一起遍歷
sjj568583225
(一樓)的回答
請不要用對答槐象加方法的形式解釋;這樣子anlod
不好理解
提清虧友問者的意思我也不是很明白,或許最後這個函數array_merge()是
anlod
想要的
我做個翻譯,如果anlod還不明白
就請補充一下問題
方便我們理解空神
謝謝
解釋一下:
比如你查詢的兩個結果:$res_1和$res_2裡面的結果是:
$res_1
=
array('a','b','c');
$res_2
=
array('d','e','f');
$res
=
array_merge($res_1,$res_2
);
print_r($res);
array([0]=>'a',,[1]=>'b',[2]=>'c',[3]=>'d',[4]=>'e',[5]=>'f');
然後就可以遍歷$res了。
I. php 如何循環遍歷出來以下數據
這個裡面是純寬json數據(各級元素包含數組對象等),需要用到json_decode()函數來轉化。因為題目給的是圖片,沒法實際給出代芹褲圓碼解答,可以參考我以前對類似問題的解嫌塌答:網頁鏈接
望採納,謝謝