8

我编写了以下代码来检查字符串是否包含特殊字符。代码对我来说看起来太复杂了,但我不知道如何让它更简单。有任何想法吗?

def containsNoSpecialChars(string: String): Boolean = {
  val pattern = "^[a-zA-Z0-9]*$".r
  return pattern.findAllIn(string).mkString.length == string.length
}                                                 //> containsNoSpecialChars: (string: String)Boolean

containsNoSpecialChars("bl!a ")                   //> res0: Boolean = false
containsNoSpecialChars("bla9")                    //> res1: Boolean = true
4

3 回答 3

17

这使用 Java 字符串:

word.matches("^[a-zA-Z0-9]*$")

或者,如果您不想处理正则表达式,可以使用以下任一方法从 Scala 的 RichString 中受益:

word.forall(_.isLetterOrDigit)

或者:

!word.exists(!_.isLetterOrDigit)
于 2013-10-31T11:15:06.337 回答
12
scala> val ordinary=(('a' to 'z') ++ ('A' to 'Z') ++ ('0' to '9')).toSet
ordinary: scala.collection.immutable.Set[Char] = Set(E, e, X, s, x, 8, 4, n, 9, N, j, y, T, Y, t, J, u, U, f, F, A, a, 5, m, M, I, i, v, G, 6, 1, V, q, Q, L, b, g, B, l, P, p, 0, 2, C, H, c, W, h, 7, r, K, w, R, 3, k, O, D, Z, o, z, S, d)

scala> def isOrdinary(s:String)=s.forall(ordinary.contains(_))
isOrdinary: (s: String)Boolean


scala> isOrdinary("abc")
res4: Boolean = true

scala> isOrdinary("abc!")
res5: Boolean = false

我使用了 Set,这是逻辑上正确的选择,但它也应该与 Vector 一起使用,这样可以避免你看到混乱的字母......

于 2013-11-03T14:43:53.137 回答
7
def containsNoSpecialChars(string: String) = string.matches("^[a-zA-Z0-9]*$")
于 2013-11-03T15:04:54.153 回答