当前位置:首页 > 网站建设 > php教程 > 正文内容

PHP删除数组中空值的方法介绍

热淘网3年前 (2019-06-12)php教程622

说来惭愧,以前在去掉数组的空值是都是强写foreach或者while的,利用这两个语法结构来删除数组中的空元素,简单代码如下:

<?php   
foreach( $arr as $k=>$v){   
    if( !$v )   
        unset( $arr[$k] );   
}   
?>

而且自我感觉还挺不错,只是这样的效率并不高也曾经试过,先将$arr转为对象,然后利用对象的特性来删除,因为:foreach是将当前操作的数组进行copy,每操作一下foreach,都是copy了一个变量,页面里面如果有太多的foreach,会是一个很大的消耗。

在网上闲逛的时候,看到人有提示用array_filter,觉得很吃惊。打开手册瞅了一下,发现自己一直就守着个宝山却不知道如何使用。

array_filter函数的功能是利用回调函数来对数组进行过滤,一直都以为用回调函数才能处理,却没有发现手册下面还有一句,如果没有回调函数,那么默认就是删除数组中值为false的项目。

<?php   

$entry = array(   
             0 => 'foo',   
             1 => false,   
             2 => -1,   
             3 => null,   
             4 => ''  
          );   

print_r(array_filter($entry));   
?>

输出值为:

Array   
(   
    [0] => foo   
    [2] => -1   
)

看来,以后还是要多看手册啊……就象array_slice一样也是个好东西。可惜以前从来没有注意过。

附:另一个例子

$strDelCodes = "A;B;;C;;C;D;;;D;D";
$rsArray = array_values (array_unique (array_diff (split (";", $strDelCodes), array (""))));

数组$rsArray中存的值为:A B C D

array_values() 函数返回一个包含给定数组中所有键值的数组,但不保留键名。

array_diff() 函数返回两个数组的差集数组。该数组包括了所有在被比较的数组中,但是不在任何其他参数数组中的键值。

array_unique() 函数移除数组中的重复的值,并返回结果数组。当几个数组元素的值相等时,只保留第一个元素,其他的元素被删除。

        返回的数组中键名不变。

array_merge() 函数把两个或多个数组合并为一个数组。

如果键名有重复,该键的键值为最后一个键名对应的值(后面的覆盖前面的)。如果数组是数字索引的,则键名会以连续方式重新索引。


扫描二维码推送至手机访问。

版权声明:本文由热淘网发布,如需转载请注明出处。

本文链接:https://www.retao5.com/jiaocheng/1356.html

分享给朋友:

相关文章

mysql索引的类型和优缺点

mysql索引的类型和优缺点

现在来介绍了数据库索引,及其优、缺点。针对MySQL索引的特点、应用进行了详细的描 述。分析了如何避免MySQL无法使用,如何使用EXPLAIN分析查询语句,如何优化MySQL索引的应用。本文摘...

MySQL配置文件my.cnf优化

MySQL配置文件my.cnf优化

MySQL 5.5.13 参数说明: [client] character-set-server = utf8 port    = 3...

查看thinkphp框架开发的网站前台源码显示一行解决办法

查看thinkphp框架开发的网站前台源码显示一行解决办法

查看页面源代码的时候 显示的代码 都在一行 解决办法在config 配置文件里面加上 'TMPL_STRIP_SPACE'=>false,    //是否去除模板文件里面...

phpMyAdmin 错误 缺少 mysqli 扩展。请检查 PHP 配置

phpMyAdmin 错误 缺少 mysqli 扩展。请检查 PHP 配置

phpMyAdmin - 错误 缺少 mysqli 扩展。请检查 PHP 配置。 <a href="Documentation.html#faqmysql" target="do...

MySQL字段类型的选择与MySQL的查询效率如何选择?

MySQL字段类型的选择与MySQL的查询效率如何选择?

要选择有助于使查询执行更快的列,应遵循如下规则(这里,“BLOB 类型”应该理解为即包含B L O B也包含TEXT 类型): 使用定长列,不使用可变长列。这条准则对被经常修改,从而...

MySQL语句优化的原则 索引优化,查询优化

MySQL语句优化的原则 索引优化,查询优化

1、使用索引来更快地遍历表。 缺省情况下建立的索引是非群集索引,但有时它并不是最佳的。在非群集索引下,数据在物理上随机存放在数据页上。 合理的索引设计要建立在对各种查询的分析和预测上。一般...

评论列表

妙文屋
3年前 (2019-06-16)

写的很好,支持一下

发表评论

访客

◎欢迎参与讨论,请在这里发表您的看法和观点。