元字符
'/.*?/' ---> .代表除换行外任意字符, *代表0次或多次, ?放在次数后面代表懒惰模式,相对于贪婪模式, 若放在元字符后面代表0次或1次;
模式修正符
'/^[a-z].*$/i' //不区分大小写
'/^[a-z].*$/s' //万能点模式 '.'可以匹配包括换行的任意字符
'/[\x{4e00}-\x{9fa5}]/u' //表示采用utf8编码进行处理
'/^[a-z].*$/U' //大U表示将贪婪模式修改懒惰模式
// '/^[a-z].*$/m' //m,多行模式,一个字符串,即使出现换行,仍然表示一个字符串整体
'/hellow(?=word)/' //正想预查 (?=) 表示hellow后面是word的字符串,反之(?!)
'/(?<=hellow)word/' //反向预查 (?<=) 表示 word前面是hellow的字符串,反之(?<!)
函数
preg_match($pattern, $str, &$ar);
preg_match_all($pattern, $str, &$ar);
中文用户名实例
preg_match('/^[(\u4E00-\u9FA5)a-zA-Z]+[(\u4E00-\u9FA5)a-zA-Z_\d]*$/',$str)