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);
}
}
?>