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. 【Element UI】使用问题记录

    [Element UI]使用问题记录 转载:https://www.cnblogs.com/yangchongxing/p/10750994.html 下载地址: https://unpkg.com/ ...

  2. 创建基于ASP.NET core 3.1 的RazorPagesMovie项目(二)-应用模型类配合基架生成工具生成Razor页面

    本节中,将学习添加用于管理跨平台的SQLLite数据库中的电影的类Movie.从ASP.NET core 模板创建的应用使用SQLLite数据库. 应用模型类(Movie)配合Entity Frame ...

  3. c++-zoo动物园

    面向对象抽象类写动物园 animal animal.h #pragma once #define _CRT_SECURE_NO_WARNINGS #include <iostream> u ...

  4. 分布式事务之解决方案(XA和2PC)

    3. 分布式事务解决方案之2PC(两阶段提交) 针对不同的分布式场景业界常见的解决方案有2PC.TCC.可靠消息最终一致性.最大努力通知这几种. 3.1. 什么是2PC 2PC即两阶段提交协议,是将整 ...

  5. k8s~跨namespace的service相互访问

    在k8s里,你可以通过服务名去访问相同namespace里的服务,然后服务可以解析到对应的pod,从而再由pod转到对应的容器里,我们可以认为这个过程有两个port的概念,service port 就 ...

  6. Dynamics 365 Portal 多语言

    Dynamics 365 Portal 的多语言分两种情况: 1.通过定义两套记录来实现,如Web Link Set.Snippet Content,都是定义两套记录,分别关联不同的语言来实现 Web ...

  7. Sqlite—数据库备份与恢复

    数据库备份 例如:备份 /www/wwwroot 下面的 task.db 数据库 1.进入数据库 [root@localhost ~]# sqlite3 /www/wwwroot/task.db 2. ...

  8. [Windows] 智慧职教刷课软件(职教雨滴1.9更新完成)

    (智慧职教刷课软件-职教雨滴)支持职教云(云课堂)的课程 2019年10月17日 16:19:57 增加支持资料库,MOOC 点击链接加入群聊[职教雨滴反馈群]:https://jq.qq.com/? ...

  9. java之动态代理设计模式

    代理:专门完成代理请求的操作类,是所有动态代理类的父类,通过此类为一个或多个接口动态地生成实现类. 弄清动态代理的关键是清楚java的反射机制,在https://www.cnblogs.com/xix ...

  10. 树上前k大的包含不重复结点的长链

    一棵树,不一定是二叉树,在每个结点最多只属于一条链的情况下,处理出其中最长的前k个的长度. 最近训练赛做到两道题了,有必要总结一下. 不过我不知道是否有更专门的叫法. 借鉴了这位大佬的博客:https ...