if (eachlline[i].contains("-")) {//存在负数
System.out.println(fileName + " EXIST NEGATIVE");
return false;
}
else if (eachlline[i].contains(".")) {//存在分数
System.out.println(fileName + " EXIST FLOAT");
return false;
}
else if(!eachlline[i].matches("[0-9]+")) {//存在非数字的字符,如果有非\t符分割会在这里提示
System.out.println(fileName + " NOT NUMBER,IT COULD CONTAIN ' ' OR OTHERS");
return false;
}
else if(Integer.parseInt(eachlline[i])==0) {//存在0
System.out.println(fileName + " EXIST ZERO");
return false;
}
}
如上代码是在实验一中对传入的txt进行数据是否合法的处理代码的一部分,实际上在这一代码中就已经使用了正则表达式进行处理,即
else if(!eachlline[i].matches("[0-9]+"))
这句话,其实际意义是检查得到的字符是否是0-9组成的数字。可见正则表达式的功能很强大。这里再回顾下正则表达式的定义:
正则表达式是形成搜索模式的字符序列。在文本中搜索数据时,可以使用此搜索模式来描述要搜索的内容。
正则表达式可以是单个字符,也可以是更复杂的模式。
正则表达式可用于执行所有类型的文本搜索和文本替换操作。
这里列出常用的一些正则表达式
\ | 将下一字符标记为特殊字符、文本、反向引用或八进制转义符。例如, n匹配字符 n。\n 匹配换行符。序列 \\\\ 匹配 \\ ,\\( 匹配 (。 |
^ | 匹配输入字符串开始的位置。如果设置了 RegExp 对象的 Multiline 属性,^ 还会与"\n"或"\r"之后的位置匹配。 |
$ | 匹配输入字符串结尾的位置。如果设置了 RegExp 对象的 Multiline 属性,$ 还会与"\n"或"\r"之前的位置匹配。 |
* | 零次或多次匹配前面的字符或子表达式。例如,zo* 匹配"z"和"zoo"。* 等效于 {0,}。 |
+ | 一次或多次匹配前面的字符或子表达式。例如,"zo+"与"zo"和"zoo"匹配,但与"z"不匹配。+ 等效于 {1,}。 |
? | 零次或一次匹配前面的字符或子表达式。例如,"do(es)?"匹配"do"或"does"中的"do"。? 等效于 {0,1}。 |
x|y | 匹配 x 或 y。例如,'z|food' 匹配"z"或"food"。'(z|f)ood' 匹配"zood"或"food"。 |
[xyz] | 字符集。匹配包含的任一字符。例如,"[abc]"匹配"plain"中的"a"。 |
[^xyz] | 反向字符集。匹配未包含的任何字符。例如,"[^abc]"匹配"plain"中"p","l","i","n"。 |
[a-z] | 字符范围。匹配指定范围内的任何字符。例如,"[a-z]"匹配"a"到"z"范围内的任何小写字母。 |
[^a-z] | 反向范围字符。匹配不在指定的范围内的任何字符。例如,"[^a-z]"匹配任何不在"a"到"z"范围内的任何字符。 |