你這樣的數(shù)組結(jié)構(gòu)肯定是不行的,每次都只會遍歷一個元素,除非你是個二維數(shù)組,二維數(shù)組里面是兩個元素,這樣才可以,比如說

創(chuàng)新互聯(lián)是一家專注于成都網(wǎng)站制作、成都網(wǎng)站建設(shè)與策劃設(shè)計,慶元網(wǎng)站建設(shè)哪家好?創(chuàng)新互聯(lián)做網(wǎng)站,專注于網(wǎng)站建設(shè)10年,網(wǎng)設(shè)計領(lǐng)域的專業(yè)建站公司;建站業(yè)務(wù)涵蓋:慶元等地區(qū)。慶元做網(wǎng)站價格咨詢:18980820575
$arr?=?[[1,2],[3,4]];
foreach?($arr?as?$key?=?$value)?{
echo?$arr[$key][0];
echo?$arr[$key][1];
}
?php
$cliest?=?Array?(?
'0'?=?Array?(?'cid'?=?1?,'pid'?=?3?,'name'?=?'分類6',?'displayorder'?=?3?,'docs'?=?18?),?
'1'?=?Array?(?'cid'?=?2?,'pid'?=?2?,'name'?=?'分類2',?'displayorder'?=?4?,'docs'?=?18?)?,
'2'?=?Array?(?'cid'?=?3?,'pid'?=?3?,'name'?=?'分類3',?'displayorder'?=?5?,'docs'?=?18?)?
);
$dliest?=?Array?(?
'0'?=?Array?(?'cid'?=?1?,'pid'?=?1?,'name'?=?'分類8',?'displayorder'?=?1?,'docs'?=?18?),?
'1'?=?Array?(?'cid'?=?2?,'pid'?=?3?,'name'?=?'分類4',?'displayorder'?=?2?,'docs'?=?18?),
'2'?=?Array?(?'cid'?=?3?,'pid'?=?3?,'name'?=?'分類1',?'displayorder'?=?2?,'docs'?=?18?)?
);
$result=?array_merge($cliest,$dliest);
foreach($result?as?$key=$value){
if($value['pid']==3){
$data[]?=?$value;?
}
}
print_r($data);
?
剛搞好,我這個比一樓好啊
$a=array("h1","h2","h3");
$b=array("c1","c2","c3");
for($a as $key = $value)
{
echo $value . $b[$key];
}
希望能夠幫到你
$a=array("h1","h2","h3");
$b=array("c1","c2","c3");
for($a?as?$key?=?$value)
{
echo?$value?.?$b[$key];
}
不行,如果兩個數(shù)組的個數(shù)一樣的話又有對應關(guān)系可以使用下面的方法進行同時遍歷
foreach($id as $key=$sid){
//這里的$key是當前數(shù)據(jù)在數(shù)組中的下標,如果兩個數(shù)組有統(tǒng)一的下標,那么就可以使用
$tmp = $smyz[$key];
//來訪問
}如果下標不統(tǒng)一就沒法做了。
如果只是簡單的輸出一個字符串的話,可以使用implode
$a=array(1,2);
$b=array(3,4);
echo implode('', $a); // 12
echo implode('', $b); // 34
遍歷數(shù)組,一般都是通過foreach或者for來遍歷。這兩個數(shù)組有什么關(guān)系,遍歷時需要達到什么操作,還需要你這邊給出一個具體的表述,否則不好回答。或者你舉個例子也可以。
補充回答:
兩個數(shù)組,可以選擇其中一個數(shù)組進行遍歷,然后在循環(huán)體中取另外一個數(shù)組的元素。這里假設(shè)兩個數(shù)組里的元素個數(shù)是一樣的,一一對應。代碼里做了簡單的處理,防止出錯。
// 假設(shè) $b, $c 如此
$b=array(1,2);
$c=array(3,4);
foreach($b as $e)
{
if(count($c)) // 如果 $c 里的元素沒了,就跳出循環(huán)
{
$txt=array_shift($c); // 取出 $c 里的一個元素
echo "lt;a href='a.php?i=".$e."'gt;".$txt."lt;/agt;";
}
else
break;
}
還是這樣子比較好:
// 假設(shè) $b, $c 如此
$b=array(1,2);
$c=array(3,4);
$len=min(count($b), count($c));
for($i=0; $i$len; $i++)
echo "a href='a.php?i=".$b[$i]."'".$c[$i]."/a";
今天有個朋友問我一個問題php遍歷數(shù)組的方法,告訴她了幾個。順便寫個文章總結(jié)下,如果總結(jié)不全還請朋友們指出
第一、foreach()
foreach()是一個用來遍歷數(shù)組中數(shù)據(jù)的最簡單有效的方法。
?php
$urls=
array('aaa','bbb','ccc','ddd');
foreach
($urls
as
$url){
echo
"This
Site
url
is
$url!
br
/";
}
?
顯示結(jié)果:
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
/";
}
?
顯示結(jié)果:
This
Site
url
is
aaa
This
Site
url
is
bbb
This
Site
url
is
ccc
This
Site
url
is
ddd
第三、for()運用for遍歷數(shù)組
?php
$urls=
array('aaa','bbb','ccc','ddd');
for
($i=
0;$i
count($urls);
$i++){
$str=
$urls[$i];
echo
"This
Site
url
is
$str.br
/";
}
?
顯示結(jié)果:
This
Site
url
is
aaa
This
Site
url
is
bbb
This
Site
url
is
ccc
This
Site
url
is
ddd
有時候有人也在問這幾種遍歷數(shù)組的方法哪個更快捷些呢,下面做個簡單的測試就明白了
===========
下面來測試三種遍歷數(shù)組的速度
===========
一般情況下,遍歷一個數(shù)組有三種方法,for、while、foreach。其中最簡單方便的是foreach。下面先讓我們來測試一下共同遍歷一個有50000個下標的一維數(shù)組所耗的時間。
?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
/';
?
測試結(jié)果:
Used
time
of
for:0.0228429(s)
Used
time
of
while:0.0544658(s)
Used
time
of
foreach:0.0085628(s)
經(jīng)過反復多次測試,結(jié)果表明,對于遍歷同樣一個數(shù)組,foreach速度最快,最慢的則是while。從原理上來看,foreach是對數(shù)組副本進行操作(通過拷貝數(shù)組),而while則通過移動數(shù)組內(nèi)部指標進行操作,一般邏輯下認為,while應該比foreach快(因為foreach在開始執(zhí)行的時候首先把數(shù)組復制進去,而while直接移動內(nèi)部指標。),但結(jié)果剛剛相反。原因應該是,foreach是PHP內(nèi)部實現(xiàn),而while是通用的循環(huán)結(jié)構(gòu)。所以,在通常應用中foreach簡單,而且效率高。在PHP5下,foreach還可以遍歷類的屬性。
以上所述就是本文的全部內(nèi)容了,希望大家能夠喜歡。
新聞標題:php想要遍歷兩個數(shù)據(jù),php遍歷數(shù)據(jù)庫
分享網(wǎng)址:http://chinadenli.net/article0/dsgjdoo.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供定制網(wǎng)站、App設(shè)計、靜態(tài)網(wǎng)站、網(wǎng)站內(nèi)鏈、企業(yè)建站、品牌網(wǎng)站制作
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)