带子串和rebus的R子串字符串

问题描述:

我正在尝试使用stringr和rebus来构建子串串的模式。我想获得的弦乐有一些共同之处,它们都以相同的数字开始和结束。示例数据位置15和22显示了我想要子集的内容。这些数字可以从1到120带子串和rebus的R子串字符串

以下是我认为将工作(我知道,我不是做陈述,他们必须是相同的,我不知道如何):

library(stringr) 
library(rebus) 

pattern <- START %R% one_or_more(DGT) %R% one_or_more(ANY_CHAR) %R% one_or_more(DGT) %R% END 

str_subset(example, pattern) 

什么是我正在寻找的正确模式?加上开始和结束是完全一样的,因为这应该使它万无一失。

数据:

example <- c("10. - 15. JAN 2017", "COMPETITION ANALYSIS", 
"WOMEN 7.5 KM SPRINT", "CHIEMGAU ARENA", "SAT 14 JAN 2017", "START TIME:", 
"END TIME:", "14:30", "15:47", "Rank Bib Name Nat T", "Loop1 Loop2 Loop3", 
"Result Behind Rank", "Time Behind Rank Time Behind Rank Time Behind Rank", 
"1 43 MAKARAINEN Kaisa FIN 0 20:51.8 0.0 1", "Cumulative Time 7:15.7 0.0 1 14:32.2 0.0 1 20:51.8 0.0 1", 
"Loop Time 7:15.7 0.0 1 7:16.5 0.0 1 6:19.6 0.0 1", "Shooting 0 33.0 +12.0 =41 0 30.0 +8.0 =42 0 1:03.0 +19.0 =48", 
"Range Time 55.5 +11.9 =35 51.9 +7.5 37 1:47.4 +18.5 38", "Course Time 6:14.5 0.0 1 6:19.9 0.0 1 6:19.6 0.0 1 18:54.0 0.0 1", 
"Penalty Time 5.7 4.7 10.4", "2 64 KOUKALOVA Gabriela CZE 0 21:13.8 +22.0 2", 
"Cumulative Time 7:24.6 +8.9 3 14:45.4 +13.2 2 21:13.8 +22.0 2" 
) 

如果它没有被rebus,按照下图stringr你可以使用grep用正则表达式(正则表达式)。这有帮助吗?

example[grepl("(^)(\\d+)(.+)(\\d+)($)", example, perl = T)] 
# [1] "1 30 HORCHLER Nadine GER 0 36:11.5 0.0 1" 
# [2] "2 1 DAHLMEIER Laura GER 3 36:14.6 +3.1 2" 

您也可以通过由([1-120])替换它限制最后捕获组(\\d+)为数字的指定范围从1到120。

+0

让我更新几个字符串到我的例子,这会导致我的问题。正如你所看到的,有一些奇怪的日期/时间。将与此一起,因为它也会选择正确的。 – Viitama

+0

您可能会在第一个数字捕获组之后引入一个空白'\\ s'来排除时间模式(因为在后面的第一个数字后面跟着冒号而不是空白),如下所示:“(^)(\\ d + )(\\ S)(+)(\\ d +)($)“' –