为了账号安全,请及时绑定邮箱和手机立即绑定

如何计算字符串列每行中给定字符的出现次数?

如何计算字符串列每行中给定字符的出现次数?

胡子哥哥 2019-09-02 11:14:07
我有一个data.frame,其中某些变量包含文本字符串。我希望计算每个字符串中给定字符的出现次数。例:q.data<-data.frame(number=1:3, string=c("greatgreat", "magic", "not"))我希望为q.data创建一个新列,其中包含字符串中“a”的出现次数(即c(2,1,0))。我管理的唯一令人费解的方法是:string.counter<-function(strings, pattern){    counts<-NULL  for(i in 1:length(strings)){    counts[i]<-length(attr(gregexpr(pattern,strings[i])[[1]], "match.length")[attr(gregexpr(pattern,strings[i])[[1]], "match.length")>0])  }return(counts)}string.counter(strings=q.data$string, pattern="a") number     string number.of.a1      1 greatgreat           22      2      magic           13      3        not           0
查看完整描述

3 回答

?
繁华开满天机

TA贡献1816条经验 获得超4个赞

stringr包提供了str_count似乎做你感兴趣的功能


# Load your example data

q.data<-data.frame(number=1:3, string=c("greatgreat", "magic", "not"), stringsAsFactors = F)

library(stringr)


# Count the number of 'a's in each element of string

q.data$number.of.a <- str_count(q.data$string, "a")

q.data

#  number     string number.of.a

#1      1 greatgreat           2

#2      2      magic           1

#3      3        not           0


查看完整回答
反对 回复 2019-09-02
?
哆啦的时光机

TA贡献1779条经验 获得超6个赞

如果你不想离开基地R,这里有一个相当简洁和富有表现力的可能性:


x <- q.data$string

lengths(regmatches(x, gregexpr("a", x)))

# [1] 2 1 0


查看完整回答
反对 回复 2019-09-02
  • 3 回答
  • 0 关注
  • 1138 浏览

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信