全部版块 我的主页
论坛 数据科学与人工智能 数据分析与数据科学 R语言论坛
1702 4
2016-04-15
有一张表为16万*786,第786列的数据只有1和2两种,我想把为1的每一行提取出来作为一张表,等于2的每一行提取出来组成另外一张表。
我写了这样的代码先用一个例子试,结果只得到最后一条符合条件的数据,求解
     [,1] [,2]
[1,]    1    1
[2,]    2    1
[3,]    3    1
[4,]    4    1
[5,]    5    2
[6,]    6    2
[7,]    7    2
[8,]    8    2


> for(i in 1:nrow(y))
+ { if(y[i,2] == 1)
+ a = rbind(y[i,])
+ }
> a
     [,1] [,2]
[1,]    4    1

二维码

扫码加我 拉你入群

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

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

全部回复
2016-4-15 12:00:09
试试subset函数
二维码

扫码加我 拉你入群

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

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

2016-4-15 12:31:11
a<-NULL
for()
{
  if(con)
  a<-rbind(a,y[i,])
}
a
二维码

扫码加我 拉你入群

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

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

2016-4-15 12:52:09
谢谢!这两个方法都可以
二维码

扫码加我 拉你入群

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

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

2016-4-15 12:56:25
你用data frame类型会很简单。R语言的编程逻辑和其他有点不一样,特别是选取,不需要做循环。
用你的例子,假设数据是一个二维vector 变量 a。


复制代码

二维码

扫码加我 拉你入群

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

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

相关推荐
栏目导航
热门文章
推荐文章

说点什么

分享

扫码加好友,拉您进群
各岗位、行业、专业交流群