-
PHP删除数组中指定值的元素常用方法实例分析
本文实例讲述了PHP删除数组中指定值的元素。分享给大家供大家参考,具体如下:
测试数组如下:
- //这是一个测试数组
- $testArr = array(
- 't' => 'qq',
- 'q' => 'qq',
- 'b' => 'baidu',
- 'a' => 'ali',
- 'm' => 'xiaomi'
- );
方法一:
foreach遍历后unset删除,这种方法也是最容易想到的方法.
- function delByValue($arr, $value){
- if(!is_array($arr)){
- return $arr;
- }
- foreach($arr as $k=>$v){
- if($v == $value){
- unset($arr[$k]);
- }
- }
- return $arr;
- }
测试:
- $testArr = delByValue($testArr,'baidu');
- print_r($testArr)
运行结果:
- Array
- (
- [t] => qq
- [q] => qq
- [a] => ali
- [m] => xiaomi
- )
方法二:
array_flip之后unset,这种方法有一个弊端,就是反转后由于有两个键值都为qq,有一个数据将会丢失,所以在使用时请谨慎).
- function delByValue($arr, $value){
- $tempArr = array_flip($arr);
- unset($tempArr[$value]);
- return array_flip($tempArr);
- }
测试:
- $testArr = delByValue($testArr,'baidu');
- print_r($testArr)
运行结果:
- Array
- (
- [q] => qq
- [a] => ali
- [m] => xiaomi
- )
方法三:
array_search,这种方法亦有弊端,array_search搜索到一个合适的值时便返回,所以在数组存在多个相关的值这种方法不适用).
- function delByValue($arr, $value){
- $key = array_search($value,$arr);
- if(isset($key)){
- unset($arr[$key]);
- }
- return $arr;
- }
测试:
$testArr = delByValue($testArr,'baidu');
print_r($testArr)
运行结果:
- Array
- (
- [t] => qq
- [q] => qq
- [a] => ali
- [m] => xiaomi
- )
方法四:
使用array_keys搜索指定的值再循环unset)
- function delByValue($arr, $value){
- $keys = array_keys($arr, $value);
- var_dump($keys);
- if(!emptyempty($keys)){
- foreach ($keys as $key) {
- unset($arr[$key]);
- }
- }
- return $arr;
- }
测试:
- $testArr = delByValue($testArr,'baidu');
- print_r($testArr)
运行结果:
- array(1) {
- [0]=>
- string(1) "b"
- }
- Array
- (
- [t] => qq
- [q] => qq
- [a] => ali
- [m] => xiaomi
- )
四种方法总结下来,真正比较可行的还是方法1和方法4了,至于这两种方法哪个更好,那就应该是具体情况具体分析了。
出处:http://www.phpfensi.com/php/20181013/11329.html
栏目列表
最新更新
nodejs爬虫
Python正则表达式完全指南
爬取豆瓣Top250图书数据
shp 地图文件批量添加字段
爬虫小试牛刀(爬取学校通知公告)
【python基础】函数-初识函数
【python基础】函数-返回值
HTTP请求:requests模块基础使用必知必会
Python初学者友好丨详解参数传递类型
如何有效管理爬虫流量?
SQL SERVER中递归
2个场景实例讲解GaussDB(DWS)基表统计信息估
常用的 SQL Server 关键字及其含义
动手分析SQL Server中的事务中使用的锁
openGauss内核分析:SQL by pass & 经典执行
一招教你如何高效批量导入与更新数据
天天写SQL,这些神奇的特性你知道吗?
openGauss内核分析:执行计划生成
[IM002]Navicat ODBC驱动器管理器 未发现数据
初入Sql Server 之 存储过程的简单使用
这是目前我见过最好的跨域解决方案!
减少回流与重绘
减少回流与重绘
如何使用KrpanoToolJS在浏览器切图
performance.now() 与 Date.now() 对比
一款纯 JS 实现的轻量化图片编辑器
关于开发 VS Code 插件遇到的 workbench.scm.
前端设计模式——观察者模式
前端设计模式——中介者模式
创建型-原型模式