如何判断一个字符串中是否都是数字

如何判断一个字符串中是否都是数字,第1张

Java中判断字符串是否全是数字

可以使用正则表达式:

public boolean isNumeric(String str) {

Pattern pattern = Pattern.compile("[0-9]*")

Matcher isNum = pattern.matcher(str)

if (!isNum.matches()) {

return false

}

return true

}

但是这个方法并不安全,没有对字符串进行空校验。

在程序执行的时候很容易抛出异常。

例如执行:

public static void main(String[] args) {

String str = null

System.out.println(BarcodeChecksum.INSTANCE.isNumeric(str))

}

就会抛出异常:

Exception in thread "main" java.lang.NullPointerException

at java.util.regex.Matcher.getTextLength(Matcher.java:1140)

at java.util.regex.Matcher.reset(Matcher.java:291)

at java.util.regex.Matcher.(Matcher.java:211)

at java.util.regex.Pattern.matcher(Pattern.java:888)

at com.ossez.bcu.util.BarcodeChecksum.isNumeric(BarcodeChecksum.java:37)

at com.ossez.bcu.util.BarcodeChecksum.main(BarcodeChecksum.java:53)

所以这个方法并不准确。

如果执行:

public static void main(String[] args) {

String str = ""

System.out.println(BarcodeChecksum.INSTANCE.isNumeric(str))

}

将会返回 true。

这说明这个方法没有对空字符串进行校验。

可以使用 Apache 的 StringUtils.isNumeric() 函数进行判断。

这个函数位于 org.apache.commons.lang.StringUtils 中。

但是,需要注意,如果传入参数为 "" 同样也会你存在判断不准确的情况,这时候需要首先对需要进行判断的参数进行非空校验,然后删除传入数据中的空格。

public static void main(String[] args) {

String str = ""

System.out.println(StringUtils.isNumeric(str))

}

上面这个函数将会返回 true。

1.使用Character.isDigit(char)判断

char num[] = str.toCharArray()//把字符串转换为字符数组

StringBuffer title = new StringBuffer()//使用StringBuffer类,把非数字放到title中

StringBuffer hire = new StringBuffer()//把数字放到hire中

for (int i = 0i <num.lengthi++) {

// 判断输入的数字是否为数字还是字符

if (Character.isDigit(num[i])) {把字符串转换为字符,再调用Character.isDigit(char)方法判断是否是数字,是返回True,否则False

hire.append(num[i])// 如果输入的是数字,把它赋给hire} else {title.append(num[i])// 如果输入的是字符,把它赋给title}}}

2.使用类型转换判断try {String str="123abc"

int num=Integer.valueOf(str)//把字符串强制转换为数字

return true//如果是数字,返回True

} catch (Exception e) {

return false//如果抛出异常,返回False}

3.使用正则表达式判断

String str = ""

boolean isNum = str.matches("[0-9]+")

//+表示1个或多个(如"3"或"225"),*表示0个或多个([0-9]*)(如""或"1"或"22"),?表示0个或1个([0-9]?)(如""或"7")

ps:这个方法只能用于判断是否是正整数

mysql有专门的函数实现你需要的功能:

FIND_IN_SET(str,strlist)

如果字符串str在由N子串组成的表strlist之中,返回一个1到N的值。一个字符串表是被“,”分隔的子串组成的一个字符串。如果第一个参数是一个常数字符串并且第二个参数是一种类型为SET的列,FIND_IN_SET()函数被优化而使用位运算!如果str不是在strlist里面或如果strlist是空字符串,返回0。如果任何一个参数是NULL,返回NULL。如果第一个参数包含一个“,”,该函数将工作不正常。

mysql>SELECT FIND_IN_SET('b','a,b,c,d')

返回值2


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/sjk/9960459.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-03
下一篇 2023-05-03

发表评论

登录后才能评论

评论列表(0条)

保存