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. 《Java基础知识》Java线程的概念

    按照规划,从本篇开始我们开启『并发』系列内容的总结,从本篇的线程开始,到线程池,到几种并发集合源码的分析,我们一点点来,希望你也有耐心,因为并发这块知识是你职业生涯始终绕不过的坎,任何一个项目都或多或 ...

  2. Django:永别了pycrypto库~

    在开发微信登陆功能时,解密用户信息需要使用到 Crypto 包,所以安装了pycrypto库. Linux.OS X 系统均可直接 pip install pycrypto . 最近换到win10下开 ...

  3. luoguP4449 于神之怒加强版

    题意 默认\(n\leqslant m\). 一波莫反后可得: \(\sum\limits_{T=1}^{n}\frac{n}{T}\frac{m}{T}\sum\limits_{d|T}d^k\mu ...

  4. SpringMVC 自定义参数解析器.

    一.简述 有没有想过像 @RequestParam.@RequestBody 这些注解的工作原理呢?为什么 form 表单.application/json 的参数能够直接封装进 Bean 对象中呢? ...

  5. python 打飞机项目 ( 基类封装 )

    项目代码 | plane # -*- coding:utf-8 -*- import pygame, time from Plane import Plane from HeroPlane impor ...

  6. 传统js和jsx与ts和tsx的区别

    一.从定义文件格式方面说 1.传统的开发模式可以定义js文件或者jsx文件2.利用ts开发定义的文件格式tsx二.定义state的状态来说 1.传统的方式直接在构造函数中使用 constructor( ...

  7. SpringBoot2 配置多数据源,整合MybatisPlus增强插件

    本文源码:GitHub·点这里 || GitEE·点这里 一.项目案例简介 1.多数据简介 实际的项目中,经常会用到不同的数据库以满足项目的实际需求.随着业务的并发量的不断增加,一个项目使用多个数据库 ...

  8. 使用EasyPOI导入导出图片出现数组越界异常

    在我使用easypoi做导出功能的时候,突然抛了一个数组越界异常,找了很久也没找到,最后猜想有可能是路径出了问题,然后打印了一下图片存放的路径,结果发现在其保存路径上存在“.”,也就是easypoi底 ...

  9. Linux(一)

    1.简单命令        1.1 ls指令         语法1:#ls  [路径]               表示列出指定路径下的文件夹和文件的名字,如果路径没有指定则列出当前路径下的(lis ...

  10. js (单个的)点击式下拉菜单

    <!DOCTYPE html> <html> <head lang="en"> <meta charset="UTF-8&quo ...