Подтвердить что ты не робот

Исключить строку, которая будет передана как регулярное выражение

Я хотел бы создать функцию, которая создает регулярное выражение, соответствующее произвольной строке, заданной на входе. Например, когда я пишу его с помощью 123$, он должен соответствовать буквально "123$", а не 123 в конце строки.

def convert( xs: String ) = (xs map ( x => "\\"+x)).mkString                 

val text = """ 123 \d+ 567 """                                                
val x = """\d+"""                                                            
val p1 = x.r                                                                 
val p2 = convert(x).r                                                        

println( p1.toString )                                                       
  \d+ // regex to match number                                               

println( ( p1 findAllIn text ).toList )                                      
  List(123, 567) // ok, numbers are matched                                  

println( p2.toString )                                                       
  \\\d\+ // regex to match "backshash d plus"                                

println( ( p2 findAllIn text ).toList )                                      
  List() // nothing matched :(                                               

Итак, последний findAllIn должен найти \d+ в тексте, но это не так. Что здесь не так?

4b9b3361

Ответ 2

Чтобы обратить больше внимания на комментарий Harold L выше, если вы хотите сделать это с помощью библиотеки Scala, которую вы можете использовать:

import scala.util.matching.Regex
Regex.quote("123$").r.findFirstIn("123$")