楼主: dairujia
1771 4

[问答] rbind()合并符合条件的数据问题 [推广有奖]

  • 0关注
  • 0粉丝

高中生

25%

还不是VIP/贵宾

-

威望
0
论坛币
9 个
通用积分
0
学术水平
0 点
热心指数
0 点
信用等级
0 点
经验
79 点
帖子
8
精华
0
在线时间
32 小时
注册时间
2015-12-28
最后登录
2017-8-16

楼主
dairujia 发表于 2016-4-15 11:38:42 |AI写论文

+2 论坛币
k人 参与回答

经管之家送您一份

应届毕业生专属福利!

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

经管之家联合CDA

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

感谢您参与论坛问题回答

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

+2 论坛币
有一张表为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

二维码

扫码加我 拉你入群

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

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

关键词:rbind bind IND bin For

沙发
langdao1688 发表于 2016-4-15 12:00:09 来自手机
试试subset函数

藤椅
jinkelazzz 发表于 2016-4-15 12:31:11
a<-NULL
for()
{
  if(con)
  a<-rbind(a,y[i,])
}
a

板凳
dairujia 发表于 2016-4-15 12:52:09
谢谢!这两个方法都可以

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


  1. #convert data type
  2. b=data.frame(a)
  3. #conditional select
  4. b[b$X2==1,]
  5. b[b$X2==2,]
复制代码

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

本版微信群
加好友,备注cda
拉您进交流群
GMT+8, 2026-1-6 16:37