R中如何根据某一变量设置java 条件变量,对另一变量进行计算

本科模拟题1_百度文库
赠送免券下载特权
10W篇文档免费专享
部分付费文档8折起
每天抽奖多种福利
两大类热门资源免费畅读
续费一年阅读会员,立省24元!
本科模拟题1
阅读已结束,下载本文需要
想免费下载更多文档?
定制HR最喜欢的简历
下载文档到电脑,同时保存到云知识,更方便管理
加入VIP
还剩9页未读,
定制HR最喜欢的简历
你可能喜欢苹果/安卓/wp
积分 25, 距离下一级还需 20 积分
道具: 涂鸦板, 彩虹炫, 雷达卡, 热点灯下一级可获得
道具: 显身卡, 匿名卡, 金钱卡
购买后可立即获得
权限: 隐身
道具: 金钱卡, 变色卡, 彩虹炫, 雷达卡, 热点灯, 涂鸦板
开心签到天数: 2 天连续签到: 1 天[LV.1]初来乍到
RT& && && &&&ACC& && &&&experiment& && && && && && &&&Type& &subject1921& && & 0& && && && &&&For-Time---1000& && && && && &H& && && && & 10& && && && & 0& && && && &&&For-Time---1000& && && && && &L& && && && & 11515& && & 1& && && && &&&For-Time---1000& && && && && &H& && && && & 12732& && & 0& && && && &&&For-Time---1000& && && && && &H& && && && & 11400& && & 1& && && && &&&For-Time---1000& && && && && &H& && && && & 11380& && & 1& && && && &&&For-Time---1000& && && && && &M1& && && &&&2
1675& && & 0& && && && &&&For-Time---1000& && && && && &H& && && && & 21274& && & 0& && && && &&&For-Time---1000& && && && && &M2& && && &&&2
1237& && & 1& && && && &&&For-Time---1000& && && && && &L& && && && &&&21054& && & 0& && && && &&&For-Time---1000& && && && && &M1& && && &&&2
985& && && &1& && && && &&&For-Time---1000& && && && && &L& && && && &&&3851& && && &1& && && && &&&For-Time---1000& && && && && &H& && && && & 31114& && & 1& && && && &&&For-Time---1000& && && && && &M2& && && &&&31355& && & 1& && && && &&&For-Time---1000& && && && && &M2& && && &&&31226& && & 1& && && && &&&For-Time---1000& && && && && &M1& && && &&&3例如我想从上边这些数据中得知subject中有几类数据(1,2,3.....)各自类别中有几个数据(如subject=1的有5个,=2的有5个诸如此类),该用怎么样的语句加以实现,谢谢各位帮助!
本帖被以下文库推荐
& |主题: 122, 订阅: 16
Ψ▄┳一大卫卍卐席尔瓦
length(which(subject==1))
length(which(subject==2))
fantuanxiaot 发表于
length(which(subject==1))
length(which(subject==2))非常感谢,请问一下如果我的subject的个数是未知的呢?例如我这次只有三个,但是以后的数据可能会有10个或是20个,那么怎么计算subject里一共有几个类别呢?
Ψ▄┳一大卫卍卐席尔瓦
unique(subject)
热心帮助其他会员
总评分:&经验 + 20&
论坛币 + 10&
fantuanxiaot 发表于
unique(subject)十分感谢!!!!
table(subject)
总评分:&论坛币 + 1&
学术水平 + 2&
热心指数 + 1&
信用等级 + 1&
得知subject中有几类数据(1,2,3.....):length(table(subject))
各自类别中有几个数据(如subject=1的有5个,=2的有5个诸如此类):table(subject)
fdhdd 发表于
得知subject中有几类数据(1,2,3.....):length(table(subject))
各自类别中有几个数据(如subject=1的 ...非常感谢~~
gfgh 发表于
table(subject)谢谢帮助~
遇到了同样的问题。
计算一列的话就用table(),,,,
如果有很多列 ,每一列都是分类变量。 怎么写这个循环呢?
初级学术勋章
初级学术勋章
初级热心勋章
初级热心勋章
中级热心勋章
中级热心勋章
中级学术勋章
中级学术勋章
初级信用勋章
初级信用勋章
中级信用勋章
中级信用勋章
高级热心勋章
高级热心勋章
高级学术勋章
高级学术勋章
特级学术勋章
特级学术勋章
特级热心勋章
高级热心勋章
高级信用勋章
高级信用勋章
特级信用勋章
高级信用勋章
&nbsp&nbsp|
&nbsp&nbsp|
&nbsp&nbsp|
&nbsp&nbsp|
&nbsp&nbsp|
&nbsp&nbsp|
如有投资本站或合作意向,请联系(010-);
邮箱:service@pinggu.org
投诉或不良信息处理:(010-)
论坛法律顾问:王进律师没有更多推荐了,
不良信息举报
举报内容:
R语言筛选出变量包含某个字条的样本
举报原因:
原文地址:
原因补充:
最多只允许输入30个字
加入CSDN,享受更精准的内容推荐,与500万程序员共同成长!Data Frame一般被翻译为数据框,感觉就像是R中的表,由行和列组成,与Matrix不同的是,每个列可以是不同的数据类型,而Matrix是必须相同的。
Data Frame每一列有列名,每一行也可以指定行名。如果不指定行名,那么就是从1开始自增的Sequence来标识每一行。
使用data.frame函数就可以初始化一个Data Frame。比如我们要初始化一个student的Data Frame其中包含ID和Name还有Gender以及Birthdate,那么代码为:
student&-data.frame(ID=c(11,12,13),Name=c("Devin","Edward","Wenli"),Gender=c("M","M","F"),Birthdate=c("","","”))
另外也可以使用read.table() read.csv()读取一个文本文件,返回的也是一个Data Frame对象。读取数据库也是返回Data Frame对象。
查看student的内容为:
& ID & Name Gender &Birthdate
1 &11 &Devin & & &M
2 &12 Edward & & &M &
3 &13 &Wenli & & &F &
这里只指定了列名为ID,Name,Gender和Birthdate,使用names函数可以查看列名,如果要查看行名,需要用到row.names函数。这里我们希望将ID作为行名,那么可以这样写:
row.names(student)&-student$ID
更简单的办法是在初始化date.frame的时候,有参数row.names可以设置行名的向量。
与Matrix一样,使用[行Index,列Index]的格式可以访问具体的元素。
比如访问第一行:
student[1,]
访问第二列:
student[,2]
使用列的Index或者列名可以选取要访问的哪些列。比如要ID和Name,那么代码为:
idname&-student[1:2]
idname&-student[c("ID","Name”)]
如果是只访问某一列,返回的是Vector类型的,那么可以使用[[或者$来访问。比如我们要所有student的Name,代码为:
name&-student[[2]]&或者name&-student[[“Name”]]&或者name&-student$Name
使用attach和detach函数可以使得访问列时不需要总是跟着变量名在前面。
比如要打印所有Name,那么可以写成:
attach(student)print(Name)detach(student)
还可以换一种简洁一点的写法就是用with函数:
with(student,{&&n&-Name&&print(n)})
这里的n作用域只在大括号内,如果想在with函数中对全局的变量进行赋值,那么需要使用&&-这样一个运算符。
修改列数据类型
接下来我们查看该对象每列的类型,使用str(student)可以得到如下结果:
'data.frame':3 obs. of &4 variables:
&$ ID & & & : num &1 2 3
&$ Name & & : Factor w/ 3 levels "Devin","Edward",..: 1 2 3
&$ Gender & : Factor w/ 2 levels "F","M": 2 2 1
&$ Birthdate: Factor w/ 3 levels "","",..: 2 1 3
默认情况下,字符串向量都会被自动识别成Factor,也就是说,ID是数字类型,其他的3个列都被定义为Factor类型了。显然这里Name应该是字符串类型,Birthdate应该是Date类型,我们需要对列的数据类型进行更改:
student$Name&-as.character(student$Name)student$Birthdate&-as.Date(student$Birthdate)
下面我们再运行str(student)看看修改后的结果:
'data.frame':3 obs. of &4 variables:
&$ ID & & & : num &11 12 13
&$ Name & & : chr &"Devin" "Edward" "Wenli"
&$ Gender & : Factor w/ 2 levels "F","M": 2 2 1
&$ Birthdate: Date, format: "" "" "”
对于以及存在的student对象,我们希望增加Age列,该列是根据Birthdate算出来的。首先需要知道怎么算年龄。我们可以使用日期函数Sys.Date()获得当前的日期,然后使用format函数获得年份,然后用两个年份相减就是年龄。好像R并没有提供几个能用的日期函数,我们只能使用format函数取出年份部分,然后转换为int类型相减。
student$Age&-as.integer(format(Sys.Date(),"%Y"))-as.integer(format(student$Birthdate,"%Y”))
这样写似乎太长了,我们可以用within函数,这个函数和之前提到过的with函数类似,可以省略变量名,不同的地方是within函数可以在其中修改变量,也就是我们这里增加Age列:
student&-within(student,{&&Age&-as.integer(format(Sys.Date(),"%Y"))-as.integer(format(Birthdate,"%Y"))})
查询一个Date Frame,返回一个满足条件的子集,这相当于数据库中的表查询,是非常常见的操作。使用行和列的Index来获取子集是最简单的方法,前面已经提到过。如果我们使用布尔向量,配合which函数,可以实现对行的过滤。比如我们要查询所有Gender为F的数据,那么我们首先对student$Gender==“F”,得到一个布尔向量:FALSE FALSE &TRUE,然后使用which函数可以将布尔向量中TRUE的Index返回,所以我们的完整查询语句就是:
student[which(student$Gender=="F"),]
注意这里列Index并没有输入,如果我们只想知道所有女生的年龄,那么可以改为:
student[which(student$Gender=="F"),"Age”]
这样的查询写法还是复杂了点,可以直接使用subset函数,那么查询会简单些,比如我们把查询条件改为年龄&30的女性,查姓名和年龄,那么查询语句为:
subset(student,Gender=="F"&&&Age&30&,select=c("Name","Age"))
使用SQL查询Data Frame
对于我这种使用了多年SQL的人来说,如果能够直接写SQL语句对Data Frame进行查询操作,那是多么方便美妙的啊,结果还真有这么一个包:sqldf。
同样是前面的需求,对应的语句就是:
library(sqldf)result&-sqldf("select&Name,Age&from&student&where&Gender='F'&and&Age&30")
对于数据库来说,对多表进行join查询是一个很正常的事情,那么在R中也可以对多个Data Frame进行连接,这就需要使用merge函数。
比如除了前面申明的student对象外,我们再申明一个score变量,记录了每个学生的科目和成绩:
score&-data.frame(SID=c(11,11,12,12,13),Course=c("Math","English","Math","Chinese","Math"),Score=c(90,80,80,95,96))
我们看看该表的内容:
& SID &Course Score
1 &11 & &Math & &90
2 &11 English & &80
3 &12 & &Math & &80
4 &12 Chinese & &95
5 &13 & &Math & &96
这里的SID就是Student里面的ID,相当于一个外键,现在要用这个ID进行inner join操作,那么对应的R语句就是:
result&-merge(student,score,by.x="ID",by.y="SID")
我们看看merge以后的结果:
&ID & Name Gender &Birthdate Age &Course Score
1 11 &Devin & & &M
&31 & &Math & &90
2 11 &Devin & & &M
&31 English & &80
3 12 Edward & & &M
&32 & &Math & &80
4 12 Edward & & &M
&32 Chinese & &95
5 13 &Wenli & & &F
&29 & &Math & &96
正如我们期望的一样join在了一起。
除了join,另外一个操作就是union,这也是数据库常用操作,那么在R中如何将两个列一样的Data Frame Union联接在一起呢?虽然R语言中有union函数,但是不是SQL的Union的意思,我们要实现Union功能,需要用到rbind函数。
rbind的两个Data Frame必须有相同的列,比如我们再申明一个student2,将两个变量rbind起来:
student2&-data.frame(ID=c(21,22),Name=c("Yan","Peng"),Gender=c("F","M"),Birthdate=c("",""),Age=c(32,31))rbind(student,student2)
阅读(...) 评论()excel 两个条件确定一个样本时,如何匹配某个变量的值_百度知道
excel 两个条件确定一个样本时,如何匹配某个变量的值
表1的变量为代码,名称,名称,数量等,表2的变量为代码,名称,职务,年龄。两个表中都只有同时确定代码和名称时才能确定唯一的列,要将表2的职务并到表1中,Excel怎么操作呢?求大神指导
我有更好的答案
代码和名称合并做辅助,用VLOOKUP,
采纳率:43%
来自团队:
方法:=INDEX(显示值的范围,sumproduct((范围=条件)*(范围=条件)*ROW(INDIRECT(&1:&&COUNTA(显示值的范围))))=VLOOKUP(条件1&条件2&条件3,IF({1,0},范围1&范围2&范围3,显示值的范围)2,0)这个是数组公式,按三键。
这相当于多条件查找1、一般使用LOOKUP函数处理2、将两个条件组合后,使用VLOOKUP函数处理
假设表1的代码,名称,数量分别在A B C列,职务在D列,表2的代码,名称,职务,年龄分别在A B C D列,第一行为表头。在表1的D2单元格中输入=vlookup(A2&B2,if({1,0},表2!A2&表2!B2,表2!C2),2,0),按回车输入这个是vlookup的多条件匹配,通过数组辅助实现的。
增加辅助列 使用VLOOKUP函数
谢谢,辅助列怎么做呢?
或直接使用 sumproduct函数
其他3条回答
为您推荐:
其他类似问题
换一换
回答问题,赢新手礼包
个人、企业类
违法有害信息,请在下方选择后提交
色情、暴力
我们会通过消息、邮箱等方式尽快将举报结果通知您。

我要回帖

更多关于 条件变量和信号量 的文章

 

随机推荐