1.自定义打印函数P

//自定义打印
function pp($data,$exit=0){
// 定义样式
$str='<pre style="display: block;padding: 9.5px;margin: 44px 0 0 0;font-size: 13px;line-height: 1.42857;color: #333;word-break: break-all;word-wrap: break-word;background-color: #F5F5F5;border: 1px solid #CCC;border-radius: 4px;">';
// 如果是boolean或者null直接显示文字;否则print
if (is_bool($data)) {
$show_data=$data ? 'true' : 'false';
}elseif (is_null($data)) {
$show_data='null';
}else{
$show_data=print_r($data,true);
}
$str.=$show_data;
$str.='</pre>';
echo $str;
if($exit)
exit;
}

效果:

2.array_clomn()  和array_combine() 和array_values()

说明

array_column ( array $input , mixed $column_key [, mixed $index_key = null ] ) 

array_column() 返回input数组中键值为column_key的列, 如果指定了可选参数index_key,那么input数组中的这一列的值将作为返回数组中对应值的键。

array_combine ( array $keys , array $values ):数组

通过使用数组中的值keys作为键并使用 values数组中的值作为对应值来 创建数组

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

例:有这样一个数组 $arr:

想取出id对应name的值 的数组

$arr = array_column($goods,'name','id');

输出为

$arr = array_combine(array_column($arr,'id'),$arr);

输出结果为

清除掉键名 : $arr = array_values($arr)   应用场景举例(循环合并数组后清除掉前面的id键名)

3.array_filter()

array_filter ( $array , $callback )

依次将 array 数组中的每个值传递到 callback 函数。如果 callback 函数返回 true,则 array 数组的当前值会被包含在返回的结果数组中。数组的键名保留不变。

如果第二个值不填,则是过滤掉数组中的空值,第二个参数可以是自定义参数,挨个把数组的值丢进自定义函数,符合条件值的就返回

例:想把数组$results中title数组为空的过滤掉

Array
(
[0] => Array
(
[id] => 61
[name] => 操作指南
[category_id] => 64
[displayorder] => 1
[title] => Array
(
[0] => Array
(
[id] => 2
[name] => 采购操作指南
[category_id] => 61
) [1] => Array
(
[id] => 3
[name] => 测试操作
[category_id] => 61
) ) ) [1] => Array
(
[id] => 62
[name] => 入驻协议
[category_id] => 64
[displayorder] => 0
[title] => Array
(
) ) [2] => Array
(
[id] => 64
[name] => 提现帮助
[category_id] => 64
[displayorder] => 0
[title] => Array
(
[0] => Array
(
[id] => 1
[name] => 提现帮助
[category_id] => 64
) ) ) )

实现代码:

$results = array_filter($results,function ($val){return !empty($val['title']);});

执行并打印后

键为1的title数值为空,就被过滤掉了

4.array_sum(array_column($array,$column));

array_sum()是计算一维数组的值的和,array_column()是从二维数组$array中取出一列$column,

下面演示计算二维数组$results的o_id这一列的和

Array
(
[0] => Array
(
[code] => LS-20191018-3860224
[sign_user] => 鏉庡皯椋�
[o_id] => 151
) [1] => Array
(
[code] => LS-20191019-8978560
[sign_user] => 鏉庣粛椋�
[o_id] => 171
) [2] => Array
(
[code] => LS-20191022-7495040
[sign_user] => 鏉庣粛椋�
[o_id] => 187
) [3] => Array
(
[code] => LS-20191022-1037312
[sign_user] => 鏉庣粛椋�
[o_id] => 187
) [4] => Array
(
[code] => LS-20191022-2244480
[sign_user] => 鏉庣粛椋�
[o_id] => 187
) [5] => Array
(
[code] => LS-20191023-5884288
[sign_user] => 鏉庣粛椋�
[o_id] => 192
) [6] => Array
(
[code] => LS-20191023-1440512
[sign_user] => 鏉庣粛椋�
[o_id] => 190
) [7] => Array
(
[code] => LS-20191023-5723264
[sign_user] => 鏉庣粛椋�
[o_id] => 200
) )
代码:
$num = array_sum(array_column($results,'o_id'));
结果:
1465

5.set_key_field()

/**
* 替换/增加 二位数组属性值 给二维数组中的每个一维数组增加若干列或者删除若干列
*
* @param array $data 需替换的二维数组
* @param array $data $key[替换的健] => $val['替换的值'] (可多个健值)
* @param array $data 需要删除的而为数组的健值 例:['id','key'...]
*/
function set_key_field($results = [],$data = [],$del_key = [])
{
if(empty($results) || empty($data) || !is_array($results) || !is_array($data))
return $results; foreach($results as &$val) {
if(!is_array($val)) {
continue;
} if(!empty($del_key)) {
foreach($del_key as $del) {
if(!empty($val[$del]))
unset($val[$del]);
}
} foreach($data as $data_key => $data_val) {
$val[$data_key] = $data_val;
}
} return $results;
}

6.array_slice() 函数

1.从数组中按条件取出值,我实际应用到的场景是从一个数组中取出最后两个元素的值

例:

<?php
$a=array("red","green","blue","yellow","brown");
print_r(array_slice($a,-2));
?>

array_slice(array,start,length,preserve)
第一个参数是要操作的数组,第二个参数是从第几个开始取,第三个可选参数是取多少个,默认取完,第四个可选参数true或false ,true保留键名,默认false重置键名

7.strip_tags() 函数

过滤掉字符串中的html标签,例如:echo strip_tags( ‘<p>222</p>’) ;输出222,把p标签过滤掉了

8.similar_text(string,string)函数

比较两个字符串的相似度,返回一个数字,例如70,说明两个字符串的相似度是70%

												

PHP收集一些常用函数与好用的自定义函数的更多相关文章

  1. Oracle自定义函数和存储过程示例,自定义函数与存储过程区别

    参考资料:http://www.newbooks.com.cn/info/60861.html oracle自定义函数学习和连接运算符(||) 贴一段中文文档示例,应该就可以开始工作了: --过程(P ...

  2. 在JS中,一个自定义函数如何调用另一个自定义函数中的变量

    function aa1511() { var chengshi="马鞍山"; var shengfen="安徽省"; return shengfen+&quo ...

  3. vue 之 render 函数不能渲染非全局自定义函数-方案

    import customCom from 'xxx.vue' render: (h) => { return h(customCom) }

  4. 数据库之mysql篇(6)—— mysql常用函数函数/自定义函数

    常用函数 运算函数 我相信你都能看懂,所以以上的不再做过多解释 然后还有个,前面漏掉的between and: 意指10是否在0到20之间,如果是返回1,否则返回0 日期函数 这个要稍微注意一下参数, ...

  5. python基础之函数(自定义函数)

    函数: 函数的定义: 初中数学函数定义:一般的,在一个变化过程中,如果有两个变量x和y,并且对于x的每一个确定的值,y都有唯一确定的值与其对应,那么我们就把x称为自变量,把y称为因变量,y是x的函数. ...

  6. asp.net MVC helper 和自定义函数@functions小结

    asp.net Razor 视图具有.cshtml后缀,可以轻松的实现c#代码和html标签的切换,大大提升了我们的开发效率.但是Razor语法还是有一些棉花糖值得我们了解一下,可以更加强劲的提升我们 ...

  7. MySQL自定义函数

    用户自定义函数(user-defined function,UDF)是一种对MySQL扩展的途径,其用法与内置函数相同. 自定义函数两个必要条件: 参数:可以有另个或多个 返回值:只能有一个 创建自定 ...

  8. 浅谈Excel开发:四 Excel 自定义函数

    我们知道,Excel中有很多内置的函数,比如求和,求平均,字符串操作函数,金融函数等等.在有些时候,结合业务要求,这些函数可能不能满足我们的需求,比如我想要一个函数能够从WebService上获取某只 ...

  9. SQL Server编程(02)自定义函数

    在编程过程中,我们通常把特定的功能语句块封装称函数,方便代码的重用.我们可以在SQL Server中自定义函数,根据函数返回值的区别,我们自定义的函数分两种:标量值函数和表值函数. 自定义函数的优点: ...

随机推荐

  1. 【IntelliJ Idea】常用快捷键

    [IntelliJ Idea]常用快捷键 转载:https://www.cnblogs.com/yangchongxing/p/10654018.html ============= 调试 ===== ...

  2. Xcode 三方库管理工具 CocoaPods 的安装流程

    1. 移除现有 Ruby 默认源: $ gem sources --remove https://rubygems.org/ 2. 使用新的 Ruby 源: $ gem sources -a http ...

  3. 人生苦短,我用Python(3)

    1.对列表进行排序: (1)使用列表对象的sort()方法: 列表对象提供了sort()方法用于对原列表中的元素进行排序.排序后原列表中的元素顺序将发生改变.改变对象的sort()方法的语法格式如下: ...

  4. java8-从Lamda到方法引用和构造引用

    一方法引用概述 经过前面2章Lamda原理引入和Lamda解析,基本就会熟练使用Lamda表达式,这次我们更深入点.来了解一下方法引用. 方法引用是特定Lamda表达式的一种简写,其思路就是能替换La ...

  5. 聊聊 print 的前世今生

    本文原创并首发于公众号[Python猫],未经授权,请勿转载. 原文地址:https://mp.weixin.qq.com/s/NuzfuH_zCZzcrmSFR04NHw (一) 上周,我翻译了一篇 ...

  6. Mysql服务彪高排查方式及索引的正确使用步骤

    原文内容来自于LZ(楼主)的印象笔记,如出现排版异常或图片丢失等问题,可查看当前链接:https://app.yinxiang.com/shard/s17/nl/19391737/12af580d-1 ...

  7. SpringCloud-使用路由网关统一访问接口(附代码下载)

    场景 SpringCloud-使用熔断器仪表盘监控熔断: https://blog.csdn.net/BADAO_LIUMANG_QIZHI/article/details/102673599 Spr ...

  8. 【iOS翻译】App启动时的响应过程

    Responding to the Launch of Your App Initialize your app’s data structures, prepare your app to run, ...

  9. MySQL基础-存储过程

    存储过程 定义:将一批为了完成特定功能的SQL语句集,根据传入的参数(也可没有),调用,完成单个sql语句更复杂的功能 存储过程思想很简单,就是SQL语句层面上的代码封装和重用 优点:1) 可封装,并 ...

  10. Linux下MySQL或MariaDB忘记root密码的解决方法

    1.vim /etc/my.cnf 2.在[mysqld]下添加一行skip-grant-tables,然后保存并退出. 3.重启mysql服务:service mysqld restart. 4.不 ...