最近做的一个项目,我把做的过程中用到的php函数总结一下。以后遇到类似的不用百度,直接看自己总结的就好了。都是一些简单基础的函数,随手记下。方便以后学习。

1、array_sum() 返回数组中的所有值的和。

2、array_filter() 过滤数组为空的值 并且保留之前的键值

例如 $array_name = array(0=>"小明",1=>"小花",2=>"",3=>"小夏");

array_filter($array_name)输出结果为array=([0]=>"",[1]=>"小花",[3]=>"小夏");

用这个函数可以判断数组中是否有为空的值

<?php
$all_num = count($_POST['odds']);
$write_num = count(array_filter($_POST['odds']));
if($all_num !== $write_num)
{
echo "数组中有为空的值";
}
?>

3、mt_rand() 使用 Mersenne Twister 算法返回随机整数。

  如果需要一个唯一的时间标识符,可以用$differ = time().mt_rand(min,max);可以用mt_rand(1000,9999)这样可以确定$differ是一个固定长度的数字。

4、str_replace() 函数以其他字符替换字符串中的一些字符(区分大小写)。

  str_replace("\r\n", "\n", $string) 字符串$string中的\r\n替换成\n。

5、判断填写的值是否为数字 正则匹配

  preg_match('正则表达式','要匹配的对象','匹配结果的数组'); 匹配返回1 不匹配返回0

  preg_match('/^\d+$/',$data['pre_beid']) //匹配数字

  //匹配url的正则表达式 

  $reg = "/^((http:\/\/)|(https:\/\/))([\w\d-]+\.)+[\w-]+(\/[\x{4e00}-\x{9fa5}\d\w-.\/?%&=]*)?$/iu";
  if (!preg_match($reg, $url)) {
  return false;
  }

  //匹配正整数的正则

  $matches = "/^[1-9][0-9]*$/";

  //匹配图片类型的正则

  preg_match("/\.(jpg|png)$/", $info_list['push_single_low']['name'][$i],$match_single_low);

  $match_single_low[0]就是图片的后缀

6、计算填写的内容个数

  mb_strlen()函数计算填写内容的个数,不管是汉字还是字符都算一个增加。后面填上字符串的编码会更精确

  mb_strlen($btn_des,'utf-8')>12;

7、转化字符函数iconv()

  $str="欢迎访问博客";

  iconv('gbk','utf8',$str);//把gbk的编码转化为utf8编码

  iconv有一个BUG 就是如果碰到不能转义的字体就会跳出来 东西会比之前的少一些,为了解决这个BUG,iconv第二个参数有两个参数TRANSLIT和IGNORE

  iconv('gbk','utf8//TRANSLIT',$str) 如果碰到不能转义的字符串可能会转义到相近的字符而不报错,继续转义。

  iconv('gbk','utf8//IGNORE',$str) 如果碰到不能转义的字符直接忽略不转义并且不报错,继续转义。

8、url转换字符

  urlencode()函数原理就是首先把中文字符转换为十六进制,然后在每个字符前面加一个标识符%,

  转换后的字符类似这样的:%B2%BB%D2%AA%C3%D4%C1%B5%B8%E7

  urldecode()函数与urlencode()函数原理相反,用于解码已编码的 URL 字符串,其原理就是把十六进制字符串转换为中文字符

9、一个转化mysql原始语句的函数

  mysql_escape_string();转化mysql语句使之成为安全的sql语句。 并不转义 %_。和mysql_real_escape_string() 完全一样,除了

  mysql_real_escape_string()接受的是一个连接句柄并根据当前字符集转移字符串之外,mysql_escape_string()并不接受连接参数,也不管当前字符集

  单个传值可以使用escape_string()函数

  

一次项目中用到的php函数总结的更多相关文章

  1. 一些项目中用到的php函数

    #不为空 if (!empty($_POST)) { } #生成随机数 mt_rand(,)产生999-9999范围间的随机数

  2. 项目中用到的SQL-总结

    基本sql总结: Group by的理解:having子句,分组函数 Group by使用的限定: 1.出现在Select列表中的字段或者出现在order by后面的字段,如果不是包含在分组函数中,那 ...

  3. 细数Java项目中用过的配置文件(YAML篇)

    灵魂拷问:YAML,在项目中用过没?它与 properties 文件啥区别? 目前 SpringBoot.SpringCloud.Docker 等各大项目.各大组件,在使用过程中几乎都能看到 YAML ...

  4. 项目中用到RouteTable,发布到IIS7中无法访问

    项目中用到RouteTable,发布到IIS7中,访问之后没有任何反应,google半天终于找到了解决方法,就是要把iis的“HTTP重定向”功能打开

  5. iOS 项目中用到的一些开源库和第三方组件

    iOS 项目中用到的一些 iOS 开源库和第三方组件 分享一下我目前所在公司 iOS 项目中用到的一些 iOS 开源库和第三方组件, 感谢开源, 减少了我们的劳动力, 节约了我们大量的时间, 让我们有 ...

  6. iOS:项目中用到的Cookie

    1.介绍: 做了这么长时间开发,Cookie真是用的不多,可是现在不一样了,这次的项目我用到了Cookie.其实,Cookie的使用在项目中愈加的频繁,一般情况下,提供的接口是用Cookie来识别用户 ...

  7. LinkedHashMap和HashMap的比较使用 由于现在项目中用到了LinkedHashMap,并不是太熟悉就到网上搜了一下。 ? import java.util.HashMap; impo

    LinkedHashMap和HashMap的比较使用 由于现在项目中用到了LinkedHashMap,并不是太熟悉就到网上搜了一下. import java.util.HashMap; import ...

  8. 项目中用到的input 遇到的问题的归类

    input 前几天 为了这个词 用在搜索框被我们总监喷,为了加强印象,我把它记录下来 最原始的造型 <input type="text" value="搜索&quo ...

  9. 在项目中用过Spring的哪些方面?及用过哪些Ajax框架?

    在项目中用过Spring的哪些方面?及用过哪些Ajax框架? 解答:在项目使用过Spring IOC ,AOP,DAO,ORM,还有上下文环境. 在项目使用过Ext,Juery等Ajax框架.

随机推荐

  1. BZOJ 1026 windy数

    Description windy定义了一种windy数.不含前导零且相邻两个数字之差至少为2的正整数被称为windy数. windy想知道,在A和B之间,包括A和B,总共有多少个windy数? In ...

  2. I/O CPU

    http://www.educity.cn/zk/czxt/201306041038131789.htm http://blog.csdn.net/xiazdong/article/details/6 ...

  3. 【UVA1379】Pitcher Rotation (贪心+DP)

    题意: 你经营者一直棒球队.在接下来的g+10天中有g(3<=g<=200)场比赛,其中每天最多一场比赛.你已经分析出你的n(5<=n<=100)个投手中每个人对阵所有m个对手 ...

  4. ios开发UI篇—在ImageView中添加按钮以及Tag的参数说明

    ios开发UI篇—在ImageView中添加按钮以及Tag的参数说明 一.tag参数 一个视图通常都只有一个父视图,多个子视图,在开发中可以通过使用子视图的tag来取出对应的子视图.方法为Viewwi ...

  5. mysql左联右联内联

    在MySQL中由于性能的关系,常常要将子查询(Sub-Queries)用连接(join)来却而代之,能够更好地使用表中索引提高查询效率. 下面介绍各种join的使用,先上图: 我们MySQL常用的为左 ...

  6. QSplashScreen开机画面(不断的repaint)

    QApplication a(argc, argv);    QPixmap pixmap(":/Image/start.png");//绑定启动图片    QSplashScre ...

  7. poj3709

    首先我们发现将一段数变为同一个数比间隔着搞肯定优,因为数列是升序的,然后不难得到方程式f[i]=min(f[j]+sum[i]-sum[j]-(i-j)*a[j+1]) (i-j>=m)简单的斜 ...

  8. Research Papers

    NSE, $\bbu$ [Papers]NSE, $u$, Lorentz space [Sohr, JEE, 2001] [Papers]NSE, $u$, Lorentz space [Bjorl ...

  9. HDOJ1175连连看 DFS

    连连看 Time Limit: 20000/10000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others) Total Submiss ...

  10. 基础排序算法之并归排序(Merge Sort)

    并归排序是学习分治法 (Merge Sort) 的好例子.而且它相对于选择,插入,冒泡排序来说,算法性能有一定提升.我首先会描述要解决的问题,并给出一个并归排序的例子.之后是算法的思路以及给出伪代码. ...