6.3.3 使用foreach语句遍历数组的应用
使用foreach语句遍历数组
•foreach循环结构:
–foreach仅用于数组,有两种语法。
foreach (array_expression as $value)
…..statement
foreach (array_expression as $key => $value)…..statement
第一种格式遍历给定的 array_expression 数组。每次循环中,当前单元的值被赋给 $value 并且数组内部的指针向前移一步
•第二种格式做同样的事,只除了当前单元的键值也会在每次循环中被赋给变量 $key。
注:当 foreach 开始执行时,数组内部的指针会自动指向第一个单元。此外注意foreach 所操作的是指定数组的一个拷贝,而不是该数组本身。
<?php
$a=array(10,20,30,40,50,60);
foreach($a as $k=>$v) {
echo "$k => $v
";
}
?>
<?php
$wage = array( //将三个部门的工资表格存储在三维数组$wage中
"市场部" => array( array(1, "高某", "市场部经理", 5000.00),
array(2, "洛某", "职员", 3000.00), array(3, "峰某", "职员", 2400.00)),
"产品部" => array( array(1, "李某", "产品部经理", 6000.00),
array(2, "周某", "职员", 4000.00), array(3, "吴某", "职员", 3200.00)),
"财务部" => array( array(1, "郑某", "财务部经理", 4500.00),
array(2, "王某", "职员", 2000.00), array(3, "冯某", "职员", 1500.00))
);
//使用三层foreach语句嵌套遍历三维数组,输出三个表格
foreach( $wage as $sector => $table ) { //最外层foreach语句遍历出三个表格,遍历出键和值
echo '<table border="1" width="600" align="center">';
echo '<caption><h2> '.$sector.'10月份工资表 </h2></caption>';
echo '<tr bgcolor="#dddddd"><th>编号</th><th>姓名</th><th>职务</th><th>工资</th></tr>';
foreach( $table as $row ) { //中层foreach语句遍历出每个表格中的行
echo '<tr>';
foreach($row as $col) { //内层foreach语句遍历出每条记录中的列值
echo '<td> '.$col.' </td>';
}
echo '</tr>';
}
echo '</table><br>';
}
test.php
<?php
/*
* 使用for遍历数组
*
*
* 保证数组: 一定要是下标连续的索引数组
*
* 优点:
*
* 效率很高, 就是数组访问方式, 只不过通过循环去取值
*
* count(数组) 获取数组的长度, 是数组的实际元素的个数
*
*不足:
1. 数组下标不一定是连续的
* 2. 关联数组for 不能遍历出值
*
*
foreach() 语法
1.
foreach(数组 as 自定义变量) {
}
一、 数组有多少个元素, foreach就循环多少次
二、foreach会将数组中的元素 在每次循环中, 依次将元素的值给自定义的变量, 在每次循环中用到这个变量,即用到了当前的数组中的元素
2.
foreach(数组 as 下标变量 => 值变量) {
}
*
*/
/* $arr = array("one"=>"aa", "bb", "three"=>"cc", "dd", 9=>"ee", "ff", "four"=>"ggg", "hh", "xxx", "yyy", "zz");
foreach($arr as $kk => $vv) {
echo "{$kk} =============> {$vv} <br>";
}
*/
$group = [
"name"=>"第三组",
"price"=>888,
["name"=>"zs", "age"=>20, "sex"=>"男", "email"=>"aaa@bbb.com"],
["name"=>"ls", "age"=>21, "sex"=>"女", "email"=>"bbb@bbb.com"],
["name"=>"ls", "age"=>21, "sex"=>"女", "email"=>"bbb@bbb.com"],
["name"=>"ls", "age"=>21, "sex"=>"女", "email"=>"bbb@bbb.com"],
["name"=>"ls", "age"=>21, "sex"=>"女", "email"=>"bbb@bbb.com"],
["name"=>"ls", "age"=>21, "sex"=>"女", "email"=>"bbb@bbb.com"],
["name"=>"ls", "age"=>21, "sex"=>"女", "email"=>"bbb@bbb.com"],
["name"=>"ls", "age"=>21, "sex"=>"女", "email"=>"bbb@bbb.com"],
["name"=>"ls", "age"=>21, "sex"=>"女", "email"=>"bbb@bbb.com"],
["name"=>"ls", "age"=>21, "sex"=>"女", "email"=>"bbb@bbb.com"],
["name"=>"ww", "age"=>22, "sex"=>"男", "email"=>"cccc@bbb.com"]
];
echo '<table border="1" width="800" align="center">';
echo '<caption><h1>数组转为表格<h1></caption>';
foreach($group as $k=>$row) {
echo '<tr>';
if(is_array($row)) {
foreach($row as $col) {
echo '<td>'.$col.'</td>';
}
} else {
echo '<td colspan="4">'.$k.':'.$row.'</td>';
}
echo '</tr>';
}
echo '</table>';