用正则表达式匹配“空值”

最近在做一个项目,要读取文本文件导入数据库,,但是为了性能和界面友好的问题,于是打算导入之前检查文本文件的格式是否正确,如果不正确,则作出相应提示而停止导入,所以要对文本文件逐行扫描,然后检查每一行的格式,如果不符合约定的格式,则提示用户对应的行数。自然而然想到用正则表达式。但是就有个问题了,文本文件中有个title字段,格式很复杂,可以包括简繁中文,甚至五角星符号,所以用正则表达式的中文匹配是不现实了,而且还要考虑gbk或者utf8编码,相当麻烦,后来换个角度想,文本的每一行的不同字段是用tab键分开的,当一行读进来的时候,需要以tab键为分隔符将一行字符串拆分成数组。

比如文本文件的一行为“t1 t2 t3”(以tab分开)我们规定的格式为“t1 t2 t3 t4”,所以发现,读进来的一行少了一个字段t4,那么怎么验证呢,其实很简单,不管怎么样,因为格式是约定好的 ,我们建立数组存放的相应字段是确定的,因而

$a=array('','','','');

循环给数组$a的每个元素赋值,我们可以用正则检查是否数组的4个元素都不为空,结果会发现$a[3]为空值,正则表达式里好像没看到检验空值的,突然想起来/s是匹配空格的,然后又想,/s{0}代表0个空格,那不就是空值么,

$pattern = "//s{0}/";

if(preg_match($pattern, $a[3]))   echo "ok";

结果答案正合我意,突然恍然大悟,这不就等于if($a[3]=="")么,汗,饶了那么大个圈子

你可能感兴趣的:(PHP,正则表达式,数据库)