- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
取以下字符向量x
x <- c("1 Date in the form", "2 Number of game",
"3 Day of week", "4-5 Visiting team and league")
我想要的结果是以下向量,其中每个字符串中的第一个大写单词,并且如果字符串包含 -
,也是最后一句话。
[1] "Date" "Number" "Day" "Visiting" "league"
所以而不是这样做
unlist(sapply(strsplit(x, "[[:blank:]]+|, "), function(y){
if(grepl("[-]", y[1])) c(y[2], tail(y,1)) else y[2]
}))
为了得到结果,我想我可以尝试将其缩短为正则表达式。结果几乎与 sub
中的这个正则表达式“相反” 。我已经尝试了各种方法来获得相反的结果,使用不同品种的[^A-Za-z]+
等等,但尚未成功。
> sub("[A-Z][a-z]+", "", x)
[1] "1 in the form" "2 of game"
[3] "3 of week" "4-5 team and league"
所以我想这是一个由两部分组成的问题。
与 sub()
或gsub()
,如何返回 "[A-Z][a-z]+"
的相反值?
如何将正则表达式编写为“匹配第一个大写单词,如果字符串包含 -
,则还匹配最后一个单词。”? p>
最佳答案
以下是一些建议:
要使用 sub
提取第一个大写单词,您可以使用
sub(".*\\b([A-Z].*?)\\b.*", "\\1", x)
#[1] "Date" "Number" "Day" "Visiting"
其中 \\b
表示单词边界。
您还可以使用一个 sub
命令提取所有单词,但请注意,您必须应用额外的步骤,因为 sub
返回的向量长度与输入向量x
的长度相同。
以下正则表达式使用前瞻 ((?=.*-)
) 来测试字符串中是否存在 -
。如果是这种情况,则提取两个词。如果不存在,则应用逻辑 or (|
) 之后的正则表达式,并仅返回第一个大写单词。
res <- sub("(?:(?=.*-).*\\b([A-Z].*?\\b ).*\\b(.+)$)|(?:.*\\b([A-Z].*?)\\b.*)",
"\\1\\2\\3", x, perl = TRUE)
# [1] "Date" "Number" "Day" "Visiting league"
为了分隔同一字符串中的多个单词,还需要一个额外的步骤:
unlist(strsplit(res, " ", fixed = TRUE))
# [1] "Date" "Number" "Day" "Visiting" "league"
关于regex - "opposite"结果的正则表达式,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/24670038/
取以下字符向量x x sub("[A-Z][a-z]+", "", x) [1] "1 in the form" "2 of game" [3]
我正在寻找与 Porter Stemmer algorithm 相反的方法,即字符串“search”将返回一个数组“searches, searched, searching etc..” 是否已经存
我是 Haskell 新手。我正在尝试在 Haskell 中创建一种迷你语言,并且希望如果可能的话有一个名为 opp (“opposite”的缩写)的高阶函数,它将许多熟悉的函数转换为它们明显的函数对
我有以下代码: neighbor(C1, C2, [C1, C2|L]). neighbor(C1, C2, [C2, C1|L]). neighbor(C1, C2, [H|L]) :- neigh
我有一个方法 strip(),这里是它的使用上下文: public String strip(String data, String tag) { ... } @param data a str
我是 Bootstrap 的新手。我有一个可用的脚本,但我在修改它时遇到了问题。 脚本做了两件事: 1) 当您点击标题时,下面的 div 打开或关闭。 2) 当您单击标题时,标题旁边会显示两个字形之一
使用 Linq;如何做 Take 的“反面”? 即而不是获取前 n 个元素,例如 in aCollection.Take(n) 我想获取除最后 n 个元素以外的所有元素。有点像 aCollection
null 合并大致转换为返回 x,除非它为 null,在这种情况下返回 y 我经常需要如果x为null则返回null,否则返回x.y 我可以使用 return x == null 吗?空 : x.y;
我使用以下脚本与文件夹进行比较: if diff "/home/folder1/" "/home/folder2/" &> /dev/null ; then echo "Files in th
我有一堆 PropertyPages 与 PropertyPage 粘在一起(以创建选项卡式 View )。其中一个页面在其 OnSetActive() 方法中启动一个计时器来刷新一些状态信息。现在,
要将一行文本分隔成两行,我正在使用: Line one line two p span { display:block } 但是在我的页面的移动版本上,我想删除元素上的那个 block
在看到可用的不同选择器后(从 CSS3 开始),+ 之间的区别和 ~似乎几乎相同。而且似乎也没有与 ~ 功能相反的选择器. 取自www.w3schools.com : div + p: Selects
我是这样写的: var destinations = db.DestinationDetails. Where(dd => dd.Language.Lang == "en-US" &&
在 ruby 中,您可以使用 & 运算符将两个数组相交。 我正在尝试获取交叉路口的其余部分。 如果我使用一个简单的案例 - 就足够了: array_1 = [0, 1] array_2 = [0]
在 Android 中,应用程序可以请求 android.permission.INTERNET 权限。这由 Android 的 UI 翻译为“完整 Internet 访问”。 是否有类似“受限互联网
我一直在尝试禁用按钮,直到操作完成,然后这应该启用按钮 按钮代码: 这是 bean FileUploadController,它是一个托管和 View 范围的 bean private bo
Git-diff 有一个选项 -G,它使用正则表达式来匹配差异。 如何反其道而行之? IE。查找添加或删除的行与给定正则表达式不匹配的差异? 最佳答案 我不认为您可以使用正则表达式来实现这一点。解决方
这是我将数据 append 到结构的方式: user.Things = append(user.Things, item.Id) 现在,如何从 user.Things 中删除 item.id?似乎没有
我该怎么做 git diff在 Atlassian SourceTree 桌面应用程序中的相反方向?换句话说,我如何让 SourceTree 做 git diff b a而不是 git diff a
我知道unix的find命令有这个选项: find -version GNU find version 4.1 -newer file Compares the modification da
我是一名优秀的程序员,十分优秀!