一次项目中用到的php函数总结
最近做的一个项目,我把做的过程中用到的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函数总结的更多相关文章
- 一些项目中用到的php函数
#不为空 if (!empty($_POST)) { } #生成随机数 mt_rand(,)产生999-9999范围间的随机数
- 项目中用到的SQL-总结
基本sql总结: Group by的理解:having子句,分组函数 Group by使用的限定: 1.出现在Select列表中的字段或者出现在order by后面的字段,如果不是包含在分组函数中,那 ...
- 细数Java项目中用过的配置文件(YAML篇)
灵魂拷问:YAML,在项目中用过没?它与 properties 文件啥区别? 目前 SpringBoot.SpringCloud.Docker 等各大项目.各大组件,在使用过程中几乎都能看到 YAML ...
- 项目中用到RouteTable,发布到IIS7中无法访问
项目中用到RouteTable,发布到IIS7中,访问之后没有任何反应,google半天终于找到了解决方法,就是要把iis的“HTTP重定向”功能打开
- iOS 项目中用到的一些开源库和第三方组件
iOS 项目中用到的一些 iOS 开源库和第三方组件 分享一下我目前所在公司 iOS 项目中用到的一些 iOS 开源库和第三方组件, 感谢开源, 减少了我们的劳动力, 节约了我们大量的时间, 让我们有 ...
- iOS:项目中用到的Cookie
1.介绍: 做了这么长时间开发,Cookie真是用的不多,可是现在不一样了,这次的项目我用到了Cookie.其实,Cookie的使用在项目中愈加的频繁,一般情况下,提供的接口是用Cookie来识别用户 ...
- LinkedHashMap和HashMap的比较使用 由于现在项目中用到了LinkedHashMap,并不是太熟悉就到网上搜了一下。 ? import java.util.HashMap; impo
LinkedHashMap和HashMap的比较使用 由于现在项目中用到了LinkedHashMap,并不是太熟悉就到网上搜了一下. import java.util.HashMap; import ...
- 项目中用到的input 遇到的问题的归类
input 前几天 为了这个词 用在搜索框被我们总监喷,为了加强印象,我把它记录下来 最原始的造型 <input type="text" value="搜索&quo ...
- 在项目中用过Spring的哪些方面?及用过哪些Ajax框架?
在项目中用过Spring的哪些方面?及用过哪些Ajax框架? 解答:在项目使用过Spring IOC ,AOP,DAO,ORM,还有上下文环境. 在项目使用过Ext,Juery等Ajax框架.
随机推荐
- BZOJ 1026 windy数
Description windy定义了一种windy数.不含前导零且相邻两个数字之差至少为2的正整数被称为windy数. windy想知道,在A和B之间,包括A和B,总共有多少个windy数? In ...
- I/O CPU
http://www.educity.cn/zk/czxt/201306041038131789.htm http://blog.csdn.net/xiazdong/article/details/6 ...
- 【UVA1379】Pitcher Rotation (贪心+DP)
题意: 你经营者一直棒球队.在接下来的g+10天中有g(3<=g<=200)场比赛,其中每天最多一场比赛.你已经分析出你的n(5<=n<=100)个投手中每个人对阵所有m个对手 ...
- ios开发UI篇—在ImageView中添加按钮以及Tag的参数说明
ios开发UI篇—在ImageView中添加按钮以及Tag的参数说明 一.tag参数 一个视图通常都只有一个父视图,多个子视图,在开发中可以通过使用子视图的tag来取出对应的子视图.方法为Viewwi ...
- mysql左联右联内联
在MySQL中由于性能的关系,常常要将子查询(Sub-Queries)用连接(join)来却而代之,能够更好地使用表中索引提高查询效率. 下面介绍各种join的使用,先上图: 我们MySQL常用的为左 ...
- QSplashScreen开机画面(不断的repaint)
QApplication a(argc, argv); QPixmap pixmap(":/Image/start.png");//绑定启动图片 QSplashScre ...
- poj3709
首先我们发现将一段数变为同一个数比间隔着搞肯定优,因为数列是升序的,然后不难得到方程式f[i]=min(f[j]+sum[i]-sum[j]-(i-j)*a[j+1]) (i-j>=m)简单的斜 ...
- Research Papers
NSE, $\bbu$ [Papers]NSE, $u$, Lorentz space [Sohr, JEE, 2001] [Papers]NSE, $u$, Lorentz space [Bjorl ...
- HDOJ1175连连看 DFS
连连看 Time Limit: 20000/10000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others) Total Submiss ...
- 基础排序算法之并归排序(Merge Sort)
并归排序是学习分治法 (Merge Sort) 的好例子.而且它相对于选择,插入,冒泡排序来说,算法性能有一定提升.我首先会描述要解决的问题,并给出一个并归排序的例子.之后是算法的思路以及给出伪代码. ...