楼主: 李会超
1821 0

[程序分享] mapply用法分享 [推广有奖]

  • 1关注
  • 31粉丝

已卖:1167份资源

教授

33%

还不是VIP/贵宾

-

威望
0
论坛币
121240 个
通用积分
62.1000
学术水平
140 点
热心指数
152 点
信用等级
84 点
经验
56173 点
帖子
1180
精华
1
在线时间
1120 小时
注册时间
2008-11-6
最后登录
2024-4-29

楼主
李会超 发表于 2017-1-16 18:21:28 |AI写论文

+2 论坛币
k人 参与回答

经管之家送您一份

应届毕业生专属福利!

求职就业群
赵安豆老师微信:zhaoandou666

经管之家联合CDA

送您一个全额奖学金名额~ !

感谢您参与论坛问题回答

经管之家送您两个论坛币!

+2 论坛币
x1<-data.frame(m1=c(1,2,3),m2=c('f,a,b,c','edfc,avv,c','g,e,f,k'),m3=c('--,c,b,d','--kr,edfc,avcv,ce','f,g,l,e,l,p'),stringsAsFactors=F)


> x1
  m1         m2                m3
1  1    f,a,b,c          --,c,b,d
2  2 edfc,avv,c --kr,edfc,avcv,ce
3  3    g,e,f,k       f,g,l,e,l,p


现在需要求m2和m3两列元素的交集个数,用如下代码
x1$gg=mapply(function(x,y) length(intersect(strsplit(x,split=',')[[1]],strsplit(y,split=',')[[1]])), x1$m2, x1$m3)

x1
  m1         m2                m3 gg
1  1    f,a,b,c          --,c,b,d  2
2  2 edfc,avv,c --kr,edfc,avcv,ce  1
3  3    g,e,f,k       f,g,l,e,l,p  3

还有一种做法使用tidyr包里面的separate_rows函数
library(tidyr)
a<-separate_rows(separate_rows(x1, m2, convert = TRUE),m3)

> a[a$m2==a$m3,]
   m1   m2   m3
11  1    b    b
14  1    c    c
19  2 edfc edfc
33  3    g    g
41  3    e    e
44  3    f    f


> table(a[a$m2==a$m3,]$m1)

1 2 3
2 1 3

二维码

扫码加我 拉你入群

请注明:姓名-公司-职位

以便审核进群资格,未注明则拒绝

关键词:apply appl App Map intersect

学无止境,坚持!

您需要登录后才可以回帖 登录 | 我要注册

本版微信群
加好友,备注cda
拉您进交流群
GMT+8, 2025-12-31 08:18