在php中要利用正则来匹配中文汉字的话我们需要了解字符串编码然后还有汉字的内码这样才可以方便快速的实现精确的匹配中文汉字出来,下面我来给大家介绍介绍。
在php中来判断字符串是否为中文,就会沿袭这个思路:
代码如下 |
复制代码 |
<?php
$str = "php编程";
if (preg_match("/^[u4e00-u9fa5]+$/",$str)) {
print("该字符串全部是中文");
} else {
print("该字符串不全部是中文");
}
?> |
不过,很快就会发现,php并不支持这样的表达,报错:
Warning: preg_match() [function.preg-match]: Compilation failed: PCRE does not support L, l, N, U,
or u at offset 3 in test.php on line 3
刚开始从google上查了很多次,想从php正则表达式对于十六进制数据的
表达方式上进行突破,发现在php中,是用x表示十六进制数据的。于是,
变换成如下的代码:
代码如下 |
复制代码 |
$str = "php编程";
if (preg_match("/^[x4e00-x9fa5]+$/",$str)) {
print("该字符串全部是中文");
} else {
print("该字符串不全部是中文");
} |
貌似不报错了,判断的结果也正确,不过把$str换成“编程”两字,结果却还是显示“该字符串不全部是中文”,看
来这样的判断还是不够准确。
如果要精准匹配中文,即匹配纯中文字符,或匹配中文字符加上全角标点,则需要根据不同编码环境使用不同方法。
下面以两种常用的编码(gb2312,utf-8)
下面给两个例子:
代码如下 |
复制代码 |
(1) ANSI编程环境下:
$strtest = “yyg中文字符yyg”;
$pregstr = "/([".chr(0xb0)."-".chr(0xf7)."][".chr(0xa1)."-".chr(0xfe)."])+/i";
if(preg_match($pregstr,$strtest,$matchArray)){
echo $matchArray[0];
}
//output:中文字符
(2) Utf-8编程环境下:
$strtest = “yyg中文字符yyg”;
$pregstr = "/[x{4e00}-x{9fa5}]+/u";
if(preg_match($pregstr,$strtest,$matchArray)){
echo $matchArray[0];
}
//output:中文字符
|
在php中数组分类很多种,如一维数组,二维数组,三维或多维数组,下面我来给大家介绍php 遍历多维数组,有需要的朋友可参考。
在php遍历数组有三个函数foreach、each、list & each下面我们看它们是如何遍历多维数组的。
先看一个遍历二维数组
代码如下 |
复制代码 |
<?php
$sports = array(
'football' => 'good',
'swimming' => 'very well',
'running' => 'not good'
);
foreach ($sports as $key => $value) {
echo $key.": ".$value."<br />";
}
?>
|
下面看遍历三维数组
例1
代码如下 |
复制代码 |
function arr_fun($arr){
if(is_array($arr)){
foreach($arr as $v){
if(is_array($v)){
arr_fun($v);
}else{
echo $v."<br>";
}
}
}else{
echo $arr."<br>";
}
}
|
例2
代码如下 |
复制代码 |
<?php
/*
* -------------------------------------------------
* Url : www.111cn.net
* Date : 2011-03-09
* -------------------------------------------------
*/
function arr_foreach ($arr)
{
if (!is_array ($arr))
{
return false;
}
foreach ($arr as $key => $val )
{
if (is_array ($val))
{
arr_foreach ($val);
}
else
{
echo $val.'<br/>';
}
}
}
$arr1 = array (1=>array(11,12,13,14=>array(141,142)),2,3,4,5);
echo '<pre>';
print_r($arr1);
echo '<pre>';
arr_foreach ($arr1);
?>
输出结果
Array
(
[1] => Array
(
[0] => 11
[1] => 12
[2] => 13
[14] => Array
(
[0] => 141
[1] => 142
)
)
[2] => 2
[3] => 3
[4] => 4
[5] => 5
)
11
12
13
141
142
2
3
4
5
|
利用list与each遍历二维数组
代码如下 |
复制代码 |
<?php
$sports = array(
'football' => 'good',
'swimming' => 'www.111cn.net',
'running' => 'not good'
);
while (list($key, $value) = each($sports)) {
echo $key.": ".$value."<br />";
}
?>
|
在php中要删除文件我们需要使用php提供的unlink()文件删除函数,下面我来给大家详细介绍利用unlink删除文件的方法,有需要的朋友可参考本教程。
unlink(filename,context)
例
代码如下 |
复制代码 |
if (unlink($file_delete)) {
echo "The file was deleted successfully.", "n";
} else {
echo "The specified file could not be deleted. Please try again.", "n";
}
|
判断文件是否存在
代码如下 |
复制代码 |
$myfile = "./test1.txt";
if (file_exists($myfile)) {
$result=unlink ($myfile);
echo $result;
}
?>
|
批量删除文件
代码如下 |
复制代码 |
function delFileUnderDir( $dirName="../Smarty/templates/templates_c" )
{
if ( $handle = opendir( "$dirName" ) ) {
while ( false !== ( $item = readdir( $handle ) ) ) {
if ( $item != "." && $item != ".." ) {
if ( is_dir( "$dirName/$item" ) ) {
delFileUnderDir( "$dirName/$item" );
} else {
if( unlink( "$dirName/$item" ) )echo "成功删除文件: $dirName/$item<br />n";
}
}
}
closedir( $handle );
}
}delDirAndFile( 'www.111cn.net');
|
例
删除目录下文件并指定那些不删除
代码如下 |
复制代码 |
<?php
header("content-Type: text/html; charset=utf-8");
//配置开始
$path=".";//在些设置所删除的目录.为当前目录 如:删除path目录,引号里请添path;
$guolv="del.php,install.php,path";//设置需要过滤的文件或文件夹用英文状态下,号分隔
//配置结束
if($_GET['action']=="del"){
$file= array_values_recursive(recurdir($path,$guolv));
foreach($file as $k => $v){
remove_directory($v);
}
}else{
echo "您的配置如下<br>
要删除的目录为:
";
if($path==".")echo "当前目录";else echo $path;
echo "<br>您要过滤的文件或文件夹有:".$guolv."<br>
如果确认过滤请<a href='?action=del'>点击此处开始删除相应的目录及目录下的所有文件</a>,如果配置不正确请到文件中修改
";
}
//删除目录及文件
function remove_directory($dir) {
foreach(glob($dir) as $fn) {
echo " removing $fn<br>n";
if (!is_writable($fn))@chmod($fn, 0777);
if(is_dir($fn)){@rmdir($fn);}else{@unlink($fn);}
}
}
//扫描目录
function recurdir($pathname,$guolv='del.php')
{
$result=array();$temp=array();
//检查目录是否有效和可读
if(!is_dir($pathname) || !is_readable($pathname))
return null;
//得到目录下的所有文件夹
$allfiles=scandir($pathname);
foreach($allfiles as $key => $filename)
{
//如果是“.”或者“..”的话则略过
if(in_array($filename,array('.','..')))continue;
if(count($guolv)>0){$lv=explode(",",$guolv);if(in_array($filename,$lv))continue;}
//得到文件完整名字
$fullname =$pathname . "/" .$filename;
//如果该文件是目录的话,递归调用recurdir
$temp[]=$fullname;
if(is_dir($fullname)){
$nowpath=explode("/",$fullname);
if(count($guolv)>0){$lv=explode(",",$guolv);if(in_array($nowpath[count($nowpath)-1],$lv))continue;}
$result[$filename] = recurdir($fullname);}
}
//最后把临时数组中的内容添加到结果数组,确保目录在前,文件在后
foreach($temp as $f){
$result[]=$f;
}
return $result;
}
//获取所有文件
function array_values_recursive($ary)
{
$lst = array();
foreach( array_keys($ary) as $k ){
$v = $ary[$k];
if (is_array($v)) {$lst = array_merge( $lst, array_values_recursive($v));}else{$lst[] = $v;}
}
return $lst;
}
?>
|
在php中为你提供memory_get_usage函数,可以检查到你服务器当前所使用的内存情况,有了这个函数我们可以实时的检查服务器状态了,下面我来介绍memory_get_usage用法。
格式化memory_get_usage()输出
代码如下 |
复制代码 |
<?php
function convert($size){
$unit=array('b','kb','mb','gb','tb','pb');
return @round($size/pow(1024,($i=floor(log($size,1024)))),2).' '.$unit[$i];
}
echo convert(memory_get_usage(true));
?>
|
输出:256 kb
PHP memory_get_usage() 函数还可以有个参数,$real_usage,其值为布尔值。默认为 FALSE,表示得到的内存使用量不包括该函数(PHP 内存管理器)占用的内存;当设置为 TRUE 时,得到的内存为不包括该函数(PHP 内存管理器)占用的内存。
例
代码如下 |
复制代码 |
if (!function_exists('memory_get_usage'))
{
function memory_get_usage()
{
$pid = getmypid();
if (IS_WIN)
{
exec('tasklist /FI "PID eq ' . $pid . '" /FO LIST', $output);
return preg_replace('/[^0-9]/', '', $output[5]) * 1024;
}
else
{
exec("ps -eo%mem,rss,pid | grep $pid", $output);
$output = explode(" ", $output[0]);
return $output[1] * 1024;
}
}
}
|
autoload机制可以使得PHP程序有可能在使用类时才自动包含类文件,而不是一开始就将所有的类文件include进来,这种机制也称为lazy loading。
下面是使用autoload机制加载Person类的例子:
代码如下 |
复制代码 |
/* autoload.php */
<?php
function __autoload($classname) {
require_once ($classname . “class.php”);
}
$person = new Person(”Altair”, 6);
var_dump ($person);
?>
|
PHP的autoload机制的实现
要在PHP中实现自动加载类,那就要说到一个魔术方法了,__autoload();这是PHP5添加的自动加载类方法。只要定义了该函数,那么如果PHP运行到该类找不到时,就会根据__autoload的规则去寻找。
自己也规划一下,跟set_include_path和get_include_path来配合使用,使自动加载类更完善点,代码飙一下(模仿magento的):
代码如下 |
复制代码 |
$paths[] = BP . DS . ‘app’ . DS . ‘local’;
$paths[] = BP . DS . ‘app’ . DS . ‘base’;
$paths[] = BP . DS . ‘lib’;
$appPath = implode(PS, $paths);
set_include_path($appPath . PS . get_include_path());
|
这样就可以为PHP添加默认的类加载环境,这里只是把路径添加到了PHP环境,如果还要继续添加规则,可以再定义__autoload函数,不过我这里是对象使用的,就换了一种方法:spl_autoload_register方法,下面是自己根据magento的规则,自己弄了一套,其实跟magento差不多。
代码如下 |
复制代码 |
class Autoload {
/**
* 自身对象
*
*/
protected static $_instance = null;
public function __construct() {
}
/*
* 实例化自身
*
*/
public static function instance() {
if (null == self::$_instance) {
self::$_instance = new self();
}
return self::$_instance;
}
/**
*
* 注册自动加载函数
*/
public static function register() {
spl_autoload_register(array(self::instance(), ‘autoload’));
}
/*
*
* 自动加载类
*/
public function autoload($class) {
if (!is_string($class)) {
return;
}
$classFile = str_replace(‘ ‘, DS, ucwords(str_replace(‘_’, ‘ ‘, $class)));
$classFile .= ‘.php’;
return include $classFile;
}
}
|
标签:[!--infotagslink--]