PHP根据key删除数组中指定的元素
php数组中元素的存在⽅式是以键值对的⽅式('key'=>'value'),有时候我们需要根据键删除数组中指定的某个元素。
function bykey_reitem($arr, $key){
if(!array_key_exists($key, $arr)){
return $arr;
}
$keys = array_keys($arr);
$index = array_search($key, $keys);
if($index !== FALSE){
array_splice($arr, $index, 1);
}
return $arr;
}
$data = array('name'=>'apple','age'=>12,'address'=>'ChinaGuangZhou');
$result = array_remove($data, 'name');
var_dump($result);
使⽤函数的说明:
1.array_search()
定义和⽤法
array_search() 函数与in_array()⼀样,在数组中查⼀个键值。如果到了该值,匹配元素的键名会被返回。如果没到,则返回false。
在 PHP 4.2.0 之前,函数在失败时返回 null ⽽不是 false。
如果第三个参数 strict 被指定为 true,则只有在数据类型和值都⼀致时才返回相应元素的键名。
语法
array_search(value,array,strict)
参数描述
value  必需。规定在数组中搜索的值。
array  必需。被搜索的数组。
strict  可选。可能的值:
true
false  默认
如果值设置为 true,还将在数组中检查给定值的类型
例⼦ 1
<?php
$a=array("a"=>"Dog","b"=>"Cat","c"=>"Horse");
echo array_search("Dog",$a);
>
2.array_splice()
定义和⽤法
array_splice()函数与array_slice()函数类似,选择数组中的⼀系列元素,但不返回,⽽是删除它们并⽤其它值代替。
如果提供了第四个参数,则之前选中的那些元素将被第四个参数指定的数组取代。
最后⽣成的数组将会返回。
语法
array_splice(array,offset,length,array)
参数描述
array    必需。规定数组。
offset  必需。数值。如果 offset 为正,则从输⼊数组中该值指定的偏移量开始移除。如果 offset 为负,则从输⼊数组末尾倒数该值指定的偏移量开始移除。
length  可选。数值。如果省略该参数,则移除数组中从 offset到结尾的所有部分。如果指定了 length 并且为正
值,则移除这么多元素。如果指定了 length 且为负值,则移除从 offset 到数组末尾倒数 length 为⽌中间所有的元
素。
array    被移除的元素由此数组中的元素替代。如果没有移除任何值,则此数组中的元素将插⼊到指定位置。
提⽰和注释
提⽰:如果函数没有删除任何元素 (length=0),则替代数组将从start 参数的位置插⼊。
注释:不保留替代数组中的键。
实例
<?php
$a1=array(0=>"Dog",1=>"Cat",2=>"Horse",3=>"Bird");
$a2=array(0=>"Tiger",1=>"Lion");
array_splice($a1,0,2,$a2);
print_r($a1);
//输出:
Array ( [0] => Tiger [1] => Lion [2] => Horse [3] => Bird )
>
//与例⼦ 1 相同,但是输出返回的数组:
<?php
$a1=array(0=>"Dog",1=>"Cat",2=>"Horse",3=>"Bird");
$a2=array(0=>"Tiger",1=>"Lion");
print_r(array_splice($a1,0,2,$a2));
>
//输出:
Array ( [0] => Dog [1] => Cat )
//length 参数设置为 0:
<?php
$a1=array(0=>"Dog",1=>"Cat");
$a2=array(0=>"Tiger",1=>"Lion");
array_splice($a1,1,0,$a2);
print_r($a1);
php指什么
>
//输出:
Array ( [0] => Dog [1] => Tiger [2] => Lion [3] => Cat )
总结
以上就是这篇⽂章的全部内容了,希望本⽂的内容对⼤家的学习或者⼯作具有⼀定的参考学习价值,谢谢⼤家对的⽀持。如果你想了解更多相关内容请查看下⾯相关链接

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。