php使用函数--举例

1. 创建多级目录
1.使用递归的思想
function mkdirs_2($path){
    if(!is_dir($path)){
        mkdirs_2(dirname($path));
        if(!mkdir($path, 0777)){
            return false;
        }
    }
    return true;
}
$path2 = 'sdfs/sds/sds/s/s/sss';
var_dump(mkdirs_2($path2));     //true;

1.思想主要是利用了递归, 先创建dir, 在创建dir/css ,在创建….
2.递归就是入栈的过程, 所以先让,dir/css/js/php/ok 先入栈, 则它会最后出栈…其它的就不说了.
3.dirname( path) path中除了最后一个目录的值, 即第一次返回是: dir/css/js/php,,,第二次返回 dir/css/js,,,最后一次是 ./

2.直接利用mkdir()创建, 第三个参数必须是true才能自动创建多级目录
function mkdirs_1($path, $mode = 0777){
    if(is_dir($path)){
        return '无法创建,已经是目录了';
    }else{
        if(mkdir($path, $mode, true)) {
            return '创建成功';
        }else{
            return '创建失败';
        }
    }
}
$path1 = 'a/b/c/d/e';
var_dump(mkdirs_1($path1));  //string '创建成功' (length=12)
2. 删除目录下的所有文件和目录
<?php
/**
 * 递归实现删除目录下的所有的文件和文件夹
 * @param $dir 要删除的目录
 * @param bool $deleteRootToo 是否删除根目录 默认不删除
 */
function unlinkRecursive($dir, $deleteRootToo = false)
{
    if(!$dh = @opendir($dir))
    {
        return;
    }
    while (false !== ($obj = readdir($dh)))
    {
        if($obj == '.' || $obj == '..')
        {
            continue;
        }
        if (!@unlink($dir . '/' . $obj))//删除文件, 如果是目录则返回false
        {
            unlinkRecursive($dir.'/'.$obj, true);
        }
    }
    closedir($dh);
    if ($deleteRootToo)
    {
        @rmdir($dir);//删除目录
    }
    return;
}
unlinkRecursive('dir');
?>

unlink(): 删除文件
rmdir(): 删除目录

3.遍历目录下的所有的文件
<?php
//遍历目录下的所有的文件 -- 递归调用
function get_all_file1($path){
    if($path != '.' && $path != '..' && is_dir($path)){     //判断是否是目录,并且不是. 和..
        $files = [];                                        //存储文件信息
        if($handle = opendir($path)){                       //打开
            while($file = readdir($handle)){                //读取
                if($file != '.' && $file != '..'){
                    $file_name = ($path . DIRECTORY_SEPARATOR . $file);
                    if(is_dir($file_name)){                 //判断是否是目录
                        $files[$file] = get_all_file1($file_name);      //递归
                    }else{
                        $files[] = $file_name;
                    }
                }
            }
        }
    }
    closedir($handle);                                          //关闭句柄
    return $files;
}
var_dump(get_all_file1('F:\Apache\www\temp\php_demo'));
?>
4.计算两个文件的相对路径
<?php
//计算出两个文件的相对路径即path2相对于$path1的相对路径
function get_relative_path($path1,$path2){
    $arr1 = explode(DIRECTORY_SEPARATOR,dirname($path1));
    $arr2 = explode(DIRECTORY_SEPARATOR,dirname($path2));
    $length = count($arr2);
    for($i = 0; $i < $length; $i++){
        if($arr1[$i] != $arr2[$i]){ //进行路径匹配
            break;
        }
    }
    if($i == 0){                    //根目录不同
        return '不在同一个目录中';
    }else if($i != 0 && $i < $length){        //在同一个个目录下
        $separator = array_fill(0, ($length-$i), '..');
        return(implode(DIRECTORY_SEPARATOR, array_merge($separator, array_slice($arr1, $i))));
    }else if($i == $length){                //路径完全相同
        return '.';
    }
}
$path1 = 'F:\Apache\www\temp\php_demo\demo.md'; //参照路径path1
$path2 = 'F:\Apache\www\temp\php_demo\demo.md';
$path3 = 'F:\Apache\www\temp\sd\ss.d\sdsfd';
$path4 = 'G:\FFOutput';
var_dump(get_relative_path($path1,$path2));
var_dump(get_relative_path($path1,$path3));
var_dump(get_relative_path($path1,$path4));
?>
5.php打印前一天的时间
<?php
//php打印前一天的时间
echo date("Y-m-d H:i:s", strtotime("-1 day"));  //2015-08-04 07:59:19
?>
6.截取中文字符串
<?php
//截取中文字符串
//1.使用正则 preg_split()--返回一维数组
function substr_utf8_1($str, $start, $length){
    return implode('', array_slice(preg_split('//us', $str, -1, PREG_SPLIT_NO_EMPTY), $start, $length));
}
$str = '你好中国 hello word';
var_dump(substr_utf8_1($str, 1, 3));            //string(9) "好中国"

//2. 使用mbstring模块
var_dump(mb_substr($str, 1, 3, 'utf-8'));       //string(9) "好中国"

//3. 使用正则 split_match_all()--返回二维数组
function substr_utf8_2($arr, $start, $length){
    preg_match_all('/./us', $arr, $ar);
    var_dump(join('', array_slice($ar[0], $start, $length)));
}
substr_utf8_2($str, 1,3 );                      //string(9) "好中国"
?>
7.获取中文字符串的长度
<?php
//获取中文字符串的长度
// 1. 使用 mb_strlen()函数
$str = '你好中国 hello word';
var_dump(mb_strlen($str, 'utf-8'));             //int(15)
// 2. 使用 正则 preg_match_all() 将字符转化为二维数组, 然后统计二维数组的长度
preg_match_all('/./us', $str, $ar);
var_dump(count($ar[0]));                        //int(15)

//3. 使用 preg_split() 转为一维数组, 统计数组的长度
var_dump(count(preg_split('//us', $str,-1, PREG_SPLIT_NO_EMPTY)));      //int(15)
?>
8.翻转中文字符串
<?php
//翻转中文字符串
//1. 使用正则 preg_split()转化为一维数组-- 对数组翻转-- 合并
function strrev_utf8_1($str){
    return join('' , array_reverse(preg_split('//us', $str, -1, PREG_SPLIT_NO_EMPTY)));
}
$str = '你好中国 hello word';
var_dump(strrev_utf8_1($str));                  //string(23) "drow olleh 国中好你"


//2. 使用正则 preg_match_all()转化为二维数组-- 对数组翻转-- 合并
function strrev_utf8_2($str){
    preg_match_all('/./us', $str, $arr);
    return join('', array_reverse($arr[0]));
}
var_dump(strrev_utf8_1($str));                  //string(23) "drow olleh 国中好你"
?>
9.翻转普通字符– 将www.去掉
<?php
//翻转普通字符-- 将www.去掉
$str = 'www.baidu.com';
// 1. 使用substr()截取字符串-- 翻转
var_dump(strrev(substr($str, 4)));              //string(9) "moc.udiab"
//2. 使用str_replace()替换字符串-- 翻转
var_dump(strrev(str_replace('www.', '', $str)));    //string(9) "moc.udiab"
?>
10.获取当前执行脚本路径和参数
<?php
//获取当前执行脚本路径和参数-- url路径是: ...../php_mianshi.php?sfs
//路径 -- 1. 路径---使用魔术常量
var_dump(__FILE__);                             //string 'F:\Apache\www\temp\php_demo\demo\php_mianshi.php' (length=48)
//路径 -- 2. 使用$_server[]全局数组
var_dump($_SERVER['SCRIPT_FILENAME']);          //string 'F:/Apache/www/temp/php_demo/demo/php_mianshi.php' (length=48)
//参数
var_dump($_SERVER['QUERY_STRING']);             //string 'sfs' (length=3)
?>
11.标准的url中获取文件扩展名
<?php
//标准的url中获取文件扩展名
//1.使用basename去除文件后的所有内容, 定位. 和? 取中间 -- 适合文件目录
function get_ext1($str){
    $file = basename($str);         //获取文件后的所有的路径(包括文件名
    $pos1 = strpos($file, '.');
    $pos2 = strpos($file, '?');
    if($pos2 === false){
        return substr($file, $pos1 + 1);
    }else{
        return substr($file, $pos1 + 1, $pos2 - $pos1 - 1);
    }
}
//2.使用pathinfo()得到一个数组 --- extension 是basename中.之后的内容
function get_ext2($str){
    $file = pathinfo($str); //第二个参数为null时   则拆分成四个数组项 dirname, basename, extension, filename
    $extension = ($file['extension']);
    $pos1 = strpos($extension, '?');
    if($pos1 === false){
        return $extension;
    }else{
        return substr($extension, 0, $pos1);
    }
}
//3.因为扩展名只有3位, 路径中没有?则直接从后截取3个字符
function get_ext3($str){
    $pos1 = strpos($str, '?');
    if($pos1 === false){
        return substr($str, -3, 3);
    }else{
        return substr($str, $pos1 - 3, 3);
    }
}
//4.使用parse_url函数拆分
function get_ext4($str){
    $path = parse_url($str);            //拆分4个数组项 scheme, host, path, query
    return substr($path['path'], -3, 3);
}
//5. 使用parse_url和pathinfo()结合
function get_ext5($str){
    $path = parse_url($str);
    $arr = pathinfo($path['path'], PATHINFO_EXTENSION);
    return $arr;
}
$str1 = 'http://www.baidu.com/index.php?sf=2&s=2';
$str2 = 'D:/www/excor/admin/index.php';
var_dump(get_ext1($str1));                              //string 'php' (length=3)
var_dump(get_ext2($str1));                              //string 'php' (length=3)
var_dump(get_ext3($str1));                              //string 'php' (length=3)
var_dump(get_ext4($str1));                              //string 'php' (length=3)
var_dump(get_ext5($str1));                              //string 'php' (length=3)
?>
12.取出指定的字符
<?php
//取出指定的字符
$str1 = 'http://www.baidu.com/index.php?sf=2&s=2';
var_dump(substr($str1, strpos($str1, '?'), 1));         //string '?' (length=1)
?>
13.下划线改成驼峰标志–命名方式
<?php
//下划线改成驼峰标志
//1. ucwords() 将字符串的中的所有单词转化为大写, 前提是 每个单词用空格分开
function change_name_1($str){
    return str_replace(' ', '', ucwords(str_replace('_',' ',$str)));
}
//2. 先转化为数组, 利用array_map执行回调函数ucfirst将每个数组项转化为大写,最后在组合成string
function change_name_2($str){
    $arr = explode("_",$str);
    $arr = array_map('ucfirst',$arr);
    return implode("",$arr);
}
$str1 = 'wangming_is_a_good_boy';
var_dump(change_name_1($str1));                 //string 'WangmingIsAGoodBoy' (length=18)
var_dump(change_name_2($str1));                 //string 'WangmingIsAGoodBoy' (length=18)
?>
14.统计字符在主字符串中出现的次数
<?php
//统计字符在主字符串中出现的次数
$str1 = 'http://www.baidu.com/index.php?sf=2&s=2';
//1. 直接使用substr_count()函数
var_dump(substr_count($str1, '.'));                  //int 3
//2. 现在按照查找的字符串转化为数组, 然后统计数组的个数 记得要减去一
var_dump(count(explode('.', $str1)) - 1);           //int 3
?>
15.取出邮箱中的域名—就是@后的
<?php
//取出邮箱中的域名---就是@后的
//1. 差分两个数组,去最后一个数组的内容
function get_email_name_1($str){
    $arr = explode('@', $str);
    return $arr[1];
}
//2.定位到@, 然后取出@之后的元素
function get_email_name_2($str){
    return substr($str, strpos($str, '@') + 1);
}
//3. 利用preg_split()拆分成一维数组
function get_email_name_3($str){
    $arr = preg_split('/@/', $str, -1, PREG_SPLIT_NO_EMPTY);
    return $arr[1];
}
//4. strstr()查找包括@之后的字符,然后在截取
function get_email_name_4($str){
    return substr(strstr($str, '@'), 1);
}
$str1 = 'sq_wming@163.com';
var_dump(get_email_name_1($str1));                      //string '163.com' (length=7)
var_dump(get_email_name_2($str1));                      //string '163.com' (length=7)
var_dump(get_email_name_3($str1));                      //string '163.com' (length=7)
var_dump(get_email_name_4($str1));                      //string '163.com' (length=7)
?>
16.is_null()
<?php
error_reporting(0);
//is_null() ---- 变量没有定义  --- 变量没有赋值--- 变量赋值为null----变量被unset 结果是: true, 否则是false
$str1;
$str2 = '';
$str3 = ' ';
$str4 = null;
$str5 = array();
$str6 = 'nihao';
unset($str6);
var_dump(is_null($str1));                               //boolean true
var_dump(is_null($str2));                               //boolean false
var_dump(is_null($str3));                               //boolean false
var_dump(is_null($str4));                               //boolean true
var_dump(is_null($str5));                               //boolean false
var_dump(is_null($str6));                               //boolean true
var_dump(is_null($str7));                               //boolean true
?>
17.去除html标签
<?php
//去除html标签 -- 使用strip_tags()
$str = '<div><span>hello world !</span></div>';
var_dump(strip_tags($str));                 //string 'hello world !' (length=13)
?>
18.判断一个日期字符是否是合法
<?php
header('Content-type:text/html; charset=utf-8');
//判断一个日期字符是否是合法的
function check_date($date){
    if(date('Y-m-d H:i:s',strtotime($date)) == $date){
        return '日期合法';
    }else{
        return '日期不合法';
    }
}
$date_str = '2015-38-02 20:45:30';
var_dump(check_date($date_str));    //string '日期不合法' (length=15)
?>
20.获取上个月的最后一天
<?php
//获取上个月的最后一天
function get_pro_month_lastday($date = ''){
    if($date == ''){
        $date = time();
    }else{
        $date = strtotime($date);
    }
    $day = date('j', $date);        //得到本月的第几天
    return date('Y-m-d', strtotime(- $day . "day", $date)); //strtotime()第一个参数设置为负的本本月的第几天,然后就得到上一个月的最后一天了
}
var_dump(get_pro_month_lastday("2015-4-4"));            //string '2015-03-31' (length=10)
?>
21.获取字符串的编码格式
<?php
//获取字符串的编码格式-- 利用mb_detect_encoding()函数
$str = 'hello world 你好啊';
$encode = mb_detect_encoding($str, array("ASCII","UTF-8","GB2312","GBK"));      //UTF-8
$encode = mb_detect_encoding($str);                                             //UTF-8
var_dump($encode);
?>
22.设置string的编码格式
<?php
//设置string的编码格式-- 利用iconv()-- 通过length可以看出, utf-8下的一个中文字符相当于3个utf-8下的普通字符, gbk则是2$str = 'hello world 你好啊';
var_dump(mb_detect_encoding($str));     //查看当前字符串的编码---结果: string 'UTF-8' (length=5)
var_dump(iconv('UTF-8', 'GBK', $str));  //string 'hello world ���ð�' (length=18)
var_dump(iconv('GBK', 'UTF-8', iconv('UTF-8', 'GBK', $str)));   //string 'hello world 你好啊' (length=21)
?>
23.多进程写入一个文件–加锁
<?php
//多进程写入一个文件--加锁
function write_file($path, $content){
    $handle = fopen($path, 'a');            //以文件追加的方式打开
    if($handle){
        if(flock($handle, LOCK_EX)){        //添加排他锁, 只有当前进程解除锁定,其它进程才能使用该文件
            fwrite($handle, $content);      //写入
            fflush($handle);                //刷新缓冲区
            flock($handle, LOCK_UN);        //解锁
            fclose($handle);                //关闭文件
        }else{
            var_dump('该文件已经锁定,目前不能访问');
        }
    }else{
        var_dump('文件无法读取,检查路径');
    }
}
$path = 'test.md';
write_file($path, '写入文件');
?>
24.给定一个数组,找出数组中重复的元素
//1.使用array_count_values()函数,统计数组中每个元素出现的次数, 最后在遍历一下
<?php
$arr = ['a','b','c','c','b'];
$len = count((array_count_values($arr)));
$temp = array_count_values($arr);
foreach($temp as $key=>$val){
    if($temp[$key] >= 2){
        var_dump($key);
    }
}
?>

//2.使用array_unqiue()去除重复数组,咋利用array_diff_assoc()按键值和数值进行比较两个数组,注意:第一个数组是参照对象
<?php
$arr = ['a','b','c','c','b'];
$temp = array_unique($arr);
var_dump(array_diff_assoc($arr,$temp));
?>

//3.数组中弹出一个元素,比较这个元素是否还在数组中,如果在表示有重复的
<?php
$arr = ['a','b','c','c','b'];
$temp = true;
while($temp){
    $temp = array_pop($arr);
    if(in_array($temp, $arr)){
        var_dump($temp);
    }
}
?>
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
1. 智慧社区背景与挑战 随着城市化的快速发展,社区面临健康、安全、邻里关系和服务质量等多方面的挑战。华为技术有限公司提出智慧社区解决方案,旨在通过先进的数字化技术应对这些问题,提升城市社区的生活质量。 2. 技术推动智慧社区发展 技术进步,特别是数字化、无线化、移动化和物联化,为城市社区的智慧化提供了可能。这些技术的应用不仅提高了社区的运行效率,也增强了居民的便利性和安全性。 3. 智慧社区的核心价值 智慧社区承载了智慧城市的核心价值,通过全面信息化处理,实现对城市各个方面的数字网络化管理、服务与决策功能,从而提升社会服务效率,整合社会服务资源。 4. 多层次、全方位的智慧社区服务 智慧社区通过构建和谐、温情、平安和健康四大社区模块,满足社区居民的多层次需求。这些服务模块包括社区医疗、安全监控、情感沟通和健康监测等。 5. 智慧社区技术框架 智慧社区技术框架强调统一平台的建设,设立数据中心,构建基础网络,并通过分层建设,实现平台能力及应用的可持续成长和扩展。 6. 感知统一平台与服务方案 感知统一平台是智慧社区的关键组成部分,通过统一的RFID身份识别和信息管理,实现社区服务的智能化和便捷化。同时,提供社区内外监控、紧急救助服务和便民服务等。 7. 健康社区的构建 健康社区模块专注于为居民提供健康管理服务,通过整合医疗资源和居民接入,实现远程医疗、慢性病管理和紧急救助等功能,推动医疗模式从治疗向预防转变。 8. 平安社区的安全保障 平安社区通过闭路电视监控、防盗报警和紧急求助等技术,保障社区居民的人身和财产安全,实现社区环境的实时监控和智能分析。 9. 温情社区的情感沟通 温情社区着重于建立社区居民间的情感联系,通过组织社区活动、一键呼叫服务和互帮互助平台,增强邻里间的交流和互助。 10. 和谐社区的资源整合 和谐社区作为社会资源的整合协调者,通过统一接入和身份识别,实现社区信息和服务的便捷获取,提升居民生活质量,促进社区和谐。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值