0

我收集了来自多个来源的文件。

每个文件都包含如下字符串:

File 1: A) B) C) D) E) 
File 2: a) b) c) d) e)
File 3: a. b. c. d. e.
File 4: a- b- c- d- e-
(...)

我知道我可以事先编写所有可能的模式,但我宁愿自动编写。

是否可以制作一个程序来读取文件并计算模式?前任:

File 1: A) B) C) D) E) # => [ABCDE]\)
File 2: a) b) c) d) e) # => [abcde]\)
File 3: a. b. c. d. e. # => [abcde]\.
File 4: a- b- c- d- e- # => [abcde]-
4

1 回答 1

1

Regexp.union足够聪明,可以避开括号,但仅此而已。

str = "A) B) C) D) E)"
p re = Regexp.union(*str.split) # => /A\)|B\)|C\)|D\)|E\)/

Perl 的Regexp::assemble可能能够做到这一点,AFAIK 没有 Ruby 等价物。

于 2016-03-28T22:07:58.260 回答