Blogger Information
Blog 26
fans 0
comment 0
visits 21823
Popular Tutorials
More>
Latest Downloads
More>
Web Effects
Website Source Code
Website Materials
Front End Template
细说数组及其函数
溪边小树
Original
677 people have browsed it

数组及其函数

  1. <?php
  2. // 数组的概述与分类
  3. // 1. 索引数组
  4. // 索引键名是数值
  5. $students = [0=>'1111', 1=>'zhangsan', 2=>'网络编程', 3=>4400];
  6. printf('<pre>%s</pre>', print_r($students, true));
  7. // 如果索引数组的键名满足从0开递增的正整数,可以省略
  8. $students = ['1111', 'zhangsan', '网络编程', 9999];
  9. // printf('<pre>%s</pre>', print_r($students, true));
  10. // 键名可以不连续, 可以是负数, 还可以是小数
  11. $students = ['1111', 5=>'zhangsan', 6=>'网络编程',7=>4400];
  12. // printf('<pre>%s</pre>', print_r($students, true));
  13. // 2. 关联数组
  14. // 键名用非数字的字符串来表示
  15. $students = ['id'=>'1111', 'name'=>'zhangsan', 'model'=>'网络编程', 'price'=>4400];
  16. printf('<pre>%s</pre>', print_r($students, true));
  17. // 如果采用数字字符串,那么索引数组其实也是关联数组
  18. $students = ['0'=>'1111','1'=>'zhangsan', '2'=>'网络编程', '3'=>4400];
  19. printf('<pre>%s</pre>', print_r($students, true));
  20. echo $students[1], $students['1'];
  21. // 所以, 可以认为索引数组是关联数组的子集, 一个分支
  22. $students = ['3'=>'1111','name'=>'zhangsan', 10=>'网络编程', 'price'=>4400];
  23. printf('<pre>%s</pre>', print_r($students, true));
  24. // 数组的定义与访问
  25. // 索引数组,array()
  26. $students1 = array('1111','zhangsan',[90,80]);
  27. printf('<pre>%s</pre>',print_r($students1,true));
  28. echo '<hr>';
  29. // 使用方括号,逐个创建数组成员/元素
  30. // 使用数组成员的更新/赋值的语法来创建
  31. // 关联数组
  32. $students2 = ['id'=>'1111','name'=>'zhangsan','scores'=>['php'=>90,'js'=>80]];
  33. printf('<pre>%s</pre>',print_r($students2,true));
  34. echo '<hr>';
  35. // 数组成员的访问方式
  36. // 索引数组成员
  37. // echo "students1[1] 的姓名: students1[2]<br>";
  38. // 关联数组成员
  39. // echo "{students2['name']} 的成绩: {students2['scores']}<br>";
  40. // 数组成员的类型, 类型不受限制
  41. // 数组的值如果仍然是数组的话, 就创建了一个多维数组,多维数组中最常用的就是二维数组
  42. // 因为从数据表查询的结果, 大多以二维数组的形式呈现
  43. echo $students2['scores']['php'];
  44. echo '<hr>';
  45. // 数组的遍历
  46. // 1. 逐个遍历
  47. // 利用数组内部的指针
  48. //$stu = ['id'=>'1111', 'name' => 'zhangsan', 'age' => 35, 'course' => 'php', 'grade' => 68];
  49. // 在没有遍历之前,数组指针指向第一个元素
  50. // current(): 当前数组成中的值, key()
  51. // printf('[ %s ] => %s<br>', key($stu), current($stu));
  52. // next($stu);
  53. // printf('[ %s ] => %s<br>', key($stu), current($stu));
  54. // next($stu);
  55. // printf('[ %s ] => %s<br>', key($stu), current($stu));
  56. // next($stu);
  57. // printf('[ %s ] => %s<br>', key($stu), current($stu));
  58. // prev($stu);
  59. // printf('[ %s ] => %s<br>', key($stu), current($stu));
  60. // end($stu);
  61. // printf('[ %s ] => %s<br>', key($stu), current($stu));
  62. // reset($stu);
  63. // printf('[ %s ] => %s<br>', key($stu), current($stu));
  64. // 2. 自动遍历
  65. $stu = ['id'=>'1111', 'name' => 'zhangsan', 'age' => 35, 'course' => 'php', 'grade' => 68];
  66. // reset($stu);
  67. // while (true) {
  68. // printf('[ %s ] => %s<br>', key($stu), current($stu));
  69. // if (next($stu)) {
  70. // continue;
  71. // } else {
  72. // break;
  73. // }
  74. // }
  75. // 只获取数组成员的值
  76. foreach($stu as $value){
  77. printf('%s***<br>',$value);
  78. }
  79. echo '<hr>';
  80. // 获取数组成员的键与值
  81. foreach($stu as $key=>$value){
  82. printf('[%s]=>%s###<br>',$key,$value);
  83. }
  84. echo '<hr>';
  85. $users =null;
  86. $users[0] = ['id'=>'1010', 'name'=>'zhangsan', 'age'=>88];
  87. $users[1] = ['id'=>'1020', 'name'=>'lisi', 'age'=>78];
  88. $users[2] = ['id'=>'1030', 'name'=>'wangwu', 'age'=>68];
  89. // 一般遍历二维数组,我们只关心值
  90. // foreach ($users as $user) {
  91. // printf('id: %s---name: %s---age: %s<br>', $user['id'], $user['name'], $user['age']);
  92. // }
  93. echo '<hr>';
  94. // 用list()对数组进行解构来遍历
  95. foreach ($users as list('id'=> $id, 'name'=> $name, 'age'=>$age)) {
  96. // printf('id: %s******name: %s******age: %s<br>', $id, $name, $age);
  97. }
  98. echo '<hr>';
  99. $staffs = null;
  100. $staffs[] = ['2020', 'zhangsan', 29, [67, 88]];
  101. $staffs[] = ['2021', 'lisi', 39, [99, 31]];
  102. $staffs[] = ['2022', 'wangwu', 49, [56, 63]];
  103. foreach ($staffs as list($id, $name, $age, list($js, $php) )) {
  104. printf('id => %s, name => %s, age => %s, js=> %s, php=>%s<br>', $id, $name, $age, $js, $php);
  105. }
  106. echo '<hr>';
  107. // foreach(): 遍历对象
  108. $obj = new stdClass();
  109. $obj->name = 'admin';
  110. $obj->email = 'admin@php.cn';
  111. $obj->role = 'custom';
  112. foreach ($obj as $prop => $value) {
  113. printf('[ %s ] => %s<br>', $prop, $value);
  114. }
  115. // 与值相关的函数
  116. // array_values($arr):返回数据中所有成员的值组成的数组,会将键名重置
  117. $arr = [3=>10, 9=> 20, 0 => 'html', 'id' => 'css', 20 => 20, 30];
  118. print_r($arr);
  119. echo '<br>';
  120. print_r(array_values($arr));
  121. echo '<hr>';
  122. // in_array($search, $arr): 检查某个元素是否存在于指定的数组中
  123. echo (in_array('html5', $arr) ? '存在' : '没有') . '<br>';
  124. // array_search($search, $arr): 搜索指定的值, 返回的是键名
  125. echo $key = array_search('css', $arr);
  126. echo $arr[$key];
  127. echo '<hr>';
  128. // array_unique($arr): 删除重复的值, "去重"函数
  129. $newArr = array_unique($arr);
  130. print_r($newArr);
  131. // 与统计相关
  132. // count($arr): 数组成员数量
  133. $arr = [10, 3, 5, 3, 10, 5, 7, 3, 10, 7, 7];
  134. printf('<pre>%s</pre>', print_r($arr,true));
  135. echo '数组成员的数量: ' . count($arr);
  136. // array_count_values($arr): 统计数组中某个值的出现的频率
  137. $res = array_count_values($arr);
  138. printf('<pre>%s</pre>', print_r($res,true));
  139. // 与计算相关
  140. $arr = [10,20,'php50', '50php',30];
  141. // '50php': 将开头的数字字符串解析出来,'php50'
  142. // 求和
  143. echo array_sum($arr). '<hr>';
  144. // 计算乘积
  145. $arr = [10,20, '50php',30];
  146. // 'php50'被解析为0
  147. echo array_product($arr);
  148. echo '<hr>';
  149. // 栈与队列
  150. // 栈: 后进先出, 最后进入的最先出来, LIFO, 添加与删除受限,只允许在一端进行
  151. // 队列: 先进先出, 最先插入的数据最先出来, FIFO, 添加与删除允许在二端进行
  152. // 1. 栈操作: 尾部进行添加与删除
  153. $stack = [];
  154. // 进栈: array_push($arr, $data,...): 返回的是当前数组中被添加成功的元素的数量
  155. echo array_push($stack,10) . '<br>';
  156. echo array_push($stack,20, 30) . '<br>';
  157. printf('<pre>%s</pre>', print_r($stack, true));
  158. // echo '<hr>';
  159. // 出栈: array_pop($stack): 返回的是出栈的元素
  160. echo array_pop($stack) . '<br>';
  161. // echo array_pop($stack) . '<br>';
  162. // echo array_pop($stack) . '<br>';
  163. // var_dump(array_pop($stack));
  164. // echo '<hr>';
  165. // 2. 栈操作: 头部进行添加与删除
  166. // 入栈: array_unshift($arr, $data,...)
  167. // echo array_unshift($stack, 'one'). '<br>';
  168. // echo array_unshift($stack, 'three', 'two'). '<br>';
  169. // printf('<pre>%s</pre>', print_r($stack, true));
  170. // echo '<hr>';
  171. // 出栈: array_shift($stack), 返回元素
  172. // echo array_shift($stack) . '<br>';
  173. // echo array_shift($stack) . '<br>';
  174. // echo array_shift($stack) . '<br>';
  175. // var_dump(array_shift($stack));
  176. // echo '<hr>';
  177. // 3. 队列操作:
  178. // 尾部进队, 头部出队: array_push() + array_shift()
  179. $queue = [];
  180. echo array_push($queue, 10, 20, 30);
  181. printf('<pre>%s</pre>', print_r($queue, true));
  182. echo '<hr>';
  183. echo array_shift($queue) . '<br>';
  184. echo array_shift($queue) . '<br>';
  185. echo array_shift($queue) . '<br>';
  186. // 头部进队, 尾部出队: array_unshift() + array_pop()
  187. echo '<hr>';
  188. echo array_unshift($queue, 'one', 'two', 'three').'ddddd';
  189. printf('<pre>%s</pre>', print_r($queue, true));
  190. echo '<hr>';
  191. echo array_pop($queue) . '<br>';
  192. echo array_pop($queue) . '<br>';
  193. echo array_pop($queue) . '<br>';
  194. // 排序: 参数数组引用传参
  195. // 1. 对值
  196. $arr = [30, 4, 82, 15, 20, 'abc', 'hello', 2, 46];
  197. // printf('原始数组:<pre>%s</pre><hr>', print_r($arr, true));
  198. // 1.1 升序
  199. sort($arr);
  200. printf('升序索引重置:<pre>%s</pre><hr>', print_r($arr, true));
  201. // // 1.2 升序,但索引不变
  202. // $arr = [30, 4, 82, 15, 20, 'abc', 'hello', 2, 46];
  203. // // a: asoc
  204. // asort($arr);
  205. // printf('升序索引不变:<pre>%s</pre><hr>', print_r($arr, true));
  206. // 1.2 降序
  207. // rsort($arr);
  208. // printf('降序索引重置:<pre>%s</pre><hr>', print_r($arr, true));
  209. // // 2.2 升序,但索引不变
  210. // $arr = [30, 4, 82, 15, 20, 'abc', 'hello', 2, 46];
  211. // // a: asoc
  212. // arsort($arr);
  213. // printf('降序索引不变:<pre>%s</pre><hr>', print_r($arr, true));
  214. // 2. 对键名排序
  215. // $arr = ['e' => 10, 'a' => 30, 'p' => 50];
  216. // // 按键名升序, k: key
  217. // ksort($arr);
  218. // printf('按键名升序:<pre>%s</pre><hr>', print_r($arr, true));
  219. // // 键名降序
  220. // $arr = ['e' => 10, 'a' => 30, 'p' => 50];
  221. // krsort($arr);
  222. // printf('按键名降序:<pre>%s</pre><hr>', print_r($arr, true));
  223. // 3. 自定义排序
  224. // $arr = [90, 33, 4, 10, 2, 12];
  225. // // 自定义升序:u: user
  226. // usort($arr, function($a, $b) {
  227. // return $a - $b;
  228. // });
  229. // printf('自定义升序:<pre>%s</pre><hr>', print_r($arr, true));
  230. // // 自定义降序:u: user
  231. // $arr = [90, 33, 4, 10, 2, 12];
  232. // usort($arr, function($a, $b) {
  233. // return $b - $a;
  234. // });
  235. // printf('自定义降序:<pre>%s</pre><hr>', print_r($arr, true));
  236. // 4. 自然排序
  237. // $arr = ['img1.jpg', 'img5.jpg', 'img10.jpg', 'img8.jpg'];
  238. // sort($arr);
  239. // printf('升序:<pre>%s</pre><hr>', print_r($arr, true));
  240. // echo '<hr>';
  241. // // 自然排序
  242. // $arr = ['img1.jpg', 'img5.jpg', 'img10.jpg', 'img8.jpg'];
  243. // natsort($arr);
  244. // printf('自然升序:<pre>%s</pre><hr>', print_r($arr, true));
  245. // 5. 乱序反转
  246. $arr = ['id' => 109, 'username' => 'peter', 'age' => 27, 'salary' => 99999];
  247. // 打乱
  248. // shuffle($arr);
  249. // printf('乱序:<pre>%s</pre><hr>', print_r($arr, true));
  250. $arr = array_reverse($arr);
  251. printf('反转:<pre>%s</pre><hr>', print_r($arr, true));
  252. // 交换键值
  253. $arr = ['name' => 'admin', 'age' => 30, 'salary' => 8888];
  254. $arr = ['name' => 'admin', 'age' => 30, 'salary' => false];
  255. $arr=@array_flip($arr);
  256. printf('交换:<pre>%s</pre><hr>', print_r($arr, true));
  257. //10个课堂未讲过的函数
  258. //查询与替换
  259. //从数组中随机取出一个或多个元素
  260. $input = array("Neo", "Morpheus", "Trinity", "Cypher", "Tank");
  261. $rand_keys = array_rand($input, 2);
  262. echo $input[$rand_keys[0]] . '<br>';
  263. echo $input[$rand_keys[1]] . '<br>';
  264. //获取多维数组中一列组成的新数组
  265. $records = array(
  266. array(
  267. 'id' => 2135,
  268. 'first_name' => 'John',
  269. 'last_name' => 'Doe',
  270. ),
  271. array(
  272. 'id' => 3245,
  273. 'first_name' => 'Sally',
  274. 'last_name' => 'Smith',
  275. ),
  276. array(
  277. 'id' => 5342,
  278. 'first_name' => 'Jane',
  279. 'last_name' => 'Jones',
  280. ),
  281. array(
  282. 'id' => 5623,
  283. 'first_name' => 'Peter',
  284. 'last_name' => 'Doe',
  285. )
  286. );
  287. $first_names = array_column($records, 'first_name');
  288. print_r($first_names);
  289. echo '<hr>';
  290. //使用后面数组的值替换第一个数组的值
  291. $base = array("orange", "banana", "apple", "raspberry");
  292. $replacements = array(0 => "pineapple", 4 => "cherry");
  293. $replacements2 = array(0 => "grape");
  294. $basket = array_replace($base, $replacements, $replacements2);
  295. print_r($basket);
  296. echo '<hr>';
  297. //使用传递的数组递归替换第一个数组的元素
  298. //array_replace_recursive()
  299. //计算数组的交集
  300. $array1 = array("a" => "green", "red", "blue");
  301. $array2 = array("b" => "green", "yellow", "red");
  302. $result = array_intersect($array1, $array2);
  303. print_r($result);
  304. echo '<hr>';
  305. //返回数组的交集,键名也做比较
  306. $array1 = array("a" => "green", "b" => "brown", "c" => "blue", "red");
  307. $array2 = array("a" => "green", "b" => "yellow", "blue", "red");
  308. $result_array = array_intersect_assoc($array1, $array2);
  309. print_r($result_array);
  310. echo '<hr>';
  311. //计算数组的差集
  312. //对比 array1 和其他一个或者多个数组,返回在 array1 中但是不在其他 array 里的值。
  313. $array1 = array("a" => "green", "red", "blue", "red");
  314. $array2 = array("b" => "green", "yellow", "red");
  315. $result = array_diff($array1, $array2);
  316. print_r($result);
  317. echo '<hr>';
  318. //返回数组的差集,键名也做比较
  319. //array_diff_assoc()
  320. //分割与合并
  321. //通过合并两个数组来创建一个新数组
  322. //创建一个数组,用一个数组的值作为其键名,另一个数组的值作为其值
  323. $a = array('green', 'red', 'yellow');
  324. $b = array('avocado', 'apple', 'banana');
  325. $c = array_combine($a, $b);
  326. print_r($c);
  327. echo '<hr>';
  328. //把一个或多个数组合并为一个数组
  329. //array_merge() 将一个或多个数组的单元合并起来,一个数组中的值附加在前一个数组的后面。返回作为结果的数组。
  330. //如果输入的数组中有相同的字符串键名,则该键名后面的值将覆盖前一个值。然而,如果数组包含数字键名,后面的值将不会覆盖原来的值,而是附加到后面。
  331. //如果只给了一个数组并且该数组是数字索引的,则键名会以连续方式重新索引。
  332. $array1 = array("color" => "red", 2, 4);
  333. $array2 = array("a", "b", "color" => "green", "shape" => "trapezoid", 4);
  334. $result = array_merge($array1, $array2);
  335. print_r($result);
  336. echo '<hr>';
  337. //将一个数组分割成多个子数组
  338. //array_chunk()参数中preserve_keys
  339. //设为 TRUE,可以使 PHP 保留输入数组中原来的键名。如果你指定了 FALSE,那每个结果数组将用从零开始的新数字索引。默认值是 FALSE。
  340. $input_array = array('a', 'b', 'c', 'd', 'e');
  341. print_r(array_chunk($input_array, 2));
  342. print_r(array_chunk($input_array, 2, true));
  343. echo '<hr>';
  344. //自动生成
  345. //根据范围创建数据,包含指定的元素
  346. //range ( mixed $start , mixed $end [, number $step = 1 ] ) : array
  347. //建立一个包含指定范围单元的数组。
  348. //参数:start,序列的第一个值。 end,序列结束于 end 的值。
  349. // step,如果设置了步长 step,会被作为单元之间的步进值。step 应该为正值。不设置step 则默认为 1。
  350. //返回值,返回的数组中从 start 到 end (含 start 和 end)的单元。
  351. // array(0, 10, 20, 30, 40, 50, 60, 70, 80, 90, 100)
  352. foreach (range(0, 100, 10) as $number) {
  353. echo $number;}
  354. echo '<hr>';
  355. //用给定的值填充数组
  356. //array_fill ( int $start_index , int $num , mixed $value ) : array
  357. //array_fill() 用 value 参数的值将一个数组填充 num 个条目,键名由 start_index 参数指定的开始。
  358. $a = array_fill(5, 6, 'banana');
  359. $b = array_fill(-2, 4, 'pear');
  360. print_r($a);
  361. print_r($b);
  362. echo '<hr>';
  363. //使用指定的键和值填充数组
  364. //array_fill_keys()
  365. //以指定长度将一个值填充进数组
  366. //array_pad() 返回 array 的一个拷贝,并用 value 将其填补到 size 指定的长度。
  367. //如果 size 为正,则填补到数组的右侧,如果为负则从左侧开始填补。
  368. //如果 size 的绝对值小于或等于 array 数组的长度则没有任何填补。有可能一次最多填补 1048576 个单元。
  369. $input = array(12, 10, 9);
  370. $result = array_pad($input, 5, 0);
  371. // result is array(12, 10, 9, 0, 0)
  372. $result = array_pad($input, -7, -1);
  373. // result is array(-1, -1, -1, -1, 12, 10, 9)
  374. $result = array_pad($input, 2, "noop");
  375. // not padded
  376. echo '<hr>';
  377. //类型转换
  378. //将数组中的值赋予一组变量(类似解构赋值)
  379. //像 array() 一样,这不是真正的函数,而是语言结构。 list() 可以在单次操作内就为一组变量赋值。
  380. $info = array('coffee', 'brown', 'caffeine');
  381. // 列出所有变量
  382. list($drink, $color, $power) = $info;
  383. echo "$drink is $color and $power makes it special.\n";
  384. echo '<hr>';
  385. //将数组元素按指定字符拼装成字符串
  386. $array = array('lastname', 'email', 'phone');
  387. $comma_separated = implode(",", $array);
  388. echo $comma_separated;
  389. echo '<hr>';
  390. //将字符串分割为数组
  391. //explode()
  392. $pizza = "piece1 piece2 piece3 piece4 piece5 piece6";
  393. $pieces = explode(" ", $pizza);
  394. echo $pieces[0]; // piece1
  395. echo $pieces[1]; // piece2
  396. echo '<hr>';
  397. //将关联数组拆分成变量名值对
  398. //假定 $var_array 是 wddx_deserialize 返回的数组
  399. $size = "large";
  400. $var_array = array("color" => "blue",
  401. "size" => "medium",
  402. "shape" => "sphere");
  403. extract($var_array, EXTR_PREFIX_SAME, "wddx");
  404. echo "$color, $size, $shape, $wddx_size\n";
  405. echo '<hr>';
  406. //将一直变量名值对拼装成一个关联数组的键值对
  407. //compact() 接受可变的参数数目。
  408. //每个参数可以是一个包括变量名的字符串或者是一个包含变量名的数组,
  409. //该数组中还可以包含其它单元内容为变量名的数组, compact() 可以递归处理。
  410. $city = "San Francisco";
  411. $state = "CA";
  412. $event = "SIGGRAPH";
  413. $location_vars = array("city", "state");
  414. $result = compact("event", "nothing_here", $location_vars);
  415. print_r($result);
  416. echo '<hr>';
  417. // 查询与替换
  418. // 1. array_slice($arr, $offset, $length, $flag): 从数组取出一部分
  419. // $stu = ['id' => 101, 'name' => '无忌', 'age' => 20, 'course' => 'php', 'grade' => 80];
  420. // $res = array_slice($stu, 0);
  421. // 获取前2个
  422. // $res = array_slice($stu, 0, 2);
  423. // 从第2个索引开始取3个
  424. // $res = array_slice($stu, 1, 3);
  425. // 第2个参数支持负数, 从倒数第3个,取2个
  426. // $res = array_slice($stu, -3, 2);
  427. // $res = array_slice($stu, 1, -1);
  428. // $res = array_slice(array_values($stu), 1, -1 , false);
  429. // $stu = array_values($stu);
  430. // $res = array_slice($stu, 1, -1 , true);
  431. // printf('<pre>%s</pre><hr>', print_r($res, true));
  432. // 2. array_splice(&$arr, ):删除数组中的一部分并用其它值代替
  433. // 可以实现对数组的: 删除, 替换/更新, 添加
  434. $arr = [10, 28, 9, 33, 56, 21, 82, 47];
  435. printf('原始数组元素: <pre>%s</pre>', print_r($arr, true));
  436. // 删除元素
  437. // array_splice($arr, 起始索引, 删除数量), 返回的是被删除元素组成的数组
  438. // $res=array_splice($arr, 1, 2);
  439. // printf('<pre>%s</pre><hr>', print_r($res, true));
  440. // 替换功能
  441. // $res=array_splice($arr, 1, 2, [888, 999]);
  442. // $res=array_splice($arr, 1, 2, [888]);
  443. // $res=array_splice($arr, 1, 2, 888);
  444. // 添加
  445. // $res=array_splice($arr, 1, 0, [888, 999]);
  446. // 负数
  447. // $res=array_splice($arr, -3, 2, [888, 999]);
  448. $res=array_splice($arr, -4, -2, [888, 999]);
  449. printf('删除的元素: <pre>%s</pre><hr>', print_r($res, true));
  450. printf('当前: <pre>%s</pre><hr>', print_r($arr, true));
  451. // 数组元素回调处理
  452. // 1.array_filter(): 用回调过滤数组中的单元,返回计算结果为true的元素组成的数组
  453. $arr = [150, 'php',true,[4,5,6], (new class {}), [], null, false, '', 0, '0'];
  454. // php自动转为false的值: null, false, 空数组, 空字符串, 0, '0'
  455. // 提示: 空对象不能转为false, 但是空数组是false
  456. $res = array_filter($arr,function($item){
  457. return $item;
  458. });
  459. $res = array_filter($arr);
  460. $res = array_filter($arr,function($item){
  461. // 只返回标量的数据
  462. // 标量: 单值变量(简单类型,string, int,float,boolean), 数组,对象不是,它们是复合
  463. return is_scalar($item) ;
  464. });
  465. // printf('<pre>%s</pre><hr>', print_r($res, true));
  466. // echo '<hr>';
  467. // 2. array_map(): 为数组中的每个元素应用回调函数进行处理,返回新数组
  468. $arr = ['php',[3,4,5], (new class {public $name='电脑';public $price=8888;}), 15, 20];
  469. $res = array_map(function($item){
  470. // 将对象和数组拉平
  471. switch (gettype($item)) {
  472. case 'object':
  473. $item = get_object_vars($item);
  474. case 'array':
  475. $item = implode(', ', $item);
  476. }
  477. return $item;
  478. }, $arr);
  479. // printf('<pre>%s</pre><hr>', print_r($res, true));
  480. echo '<hr>';
  481. // array_map(): 同时处理多个数组
  482. $key = ['host', 'username', 'password'];
  483. $values = ['localhost', 'root', '123456'];
  484. // $res = array_combine($key, $values);
  485. $res = array_map(function($value1, $value2) {
  486. return [$value1 => $value2];
  487. }, $key, $values);
  488. printf('<pre>%s</pre><hr>', print_r($res, true));
  489. echo $res[2]['password'];
  490. echo '<hr>';
  491. // 3. array_reduce(): 迭代处理数组元素
  492. function my_array_reduce($array, $callback, $init=null) {
  493. // $prev
  494. $prev = $init;
  495. foreach ($array as $current) {
  496. $prev = $callback($prev,$current);
  497. }
  498. return $prev;
  499. }
  500. $result=my_array_reduce($res, function($prev, $current){
  501. // 获取当前元素的键
  502. $key = key($current);
  503. // 获取当前元素的值
  504. $value = current($current);
  505. // 拼装成键值对
  506. $prev[$key] = $value;
  507. return $prev;
  508. });
  509. // printf('自定义迭代:<pre>%s</pre><hr>', print_r($result, true));
  510. echo '<hr>';
  511. $res=array_reduce($res, function($prev, $current){
  512. // 获取当前元素的键
  513. $key = key($current);
  514. // 获取当前元素的值
  515. $value = current($current);
  516. // 拼装成键值对
  517. $prev[$key] = $value;
  518. return $prev;
  519. });
  520. // printf('内置的数组迭代:<pre>%s</pre><hr>', print_r($res, true));
  521. // 4. array_walk(): 使用自定义回调对数组中成员逐个处理,返回布尔值
  522. // 主要用于数组成员 的格式化, 不受数组指针影响
  523. $res = ['id'=>10, 'name'=>'admin', 'email'=>'admin@php.cn'];
  524. // array_walk(数组, 回调,回调的第三个数组的默认值)
  525. array_walk($res, function($value, $key, $color) {
  526. printf('[ %s ] => <span style="color:%s">%s</span><br>',$key,$color, $value );
  527. },'green');

课程学习小结

利用五一假期的时间,对前的学习的数组及函数相关内容进行了较为全面地复习,包括回看视频及讲义代码,对照函数大全,尝试着逐个函数去实现一下,鉴于函数内容众多,部分参考老师授课实例,部分自己举例,部分借鉴技术手册案例,虽然这样全面地复习比较费时费力,但完成后,特别是上课时感觉没怎么听懂的地方,通过复习,基本知识点都能消化了,还是感觉内心很充实。希望将面向对象部分内容也能做这样的总结,但时间有限,也需要从方式方法上做些调整,尽量提高学习效率。

Correcting teacher:天蓬老师天蓬老师

Correction status:qualified

Teacher's comments:编程, 看是学不会的, 必须动动手
Statement of this Website
The copyright of this blog article belongs to the blogger. Please specify the address when reprinting! If there is any infringement or violation of the law, please contact admin@php.cn Report processing!
All comments Speak rationally on civilized internet, please comply with News Comment Service Agreement
0 comments
Author's latest blog post