楼主: 9lotus
12549 8

如何表示R中Dataframe的行序号? [推广有奖]

  • 0关注
  • 0粉丝

nobody

已卖:15份资源

本科生

7%

还不是VIP/贵宾

-

威望
0
论坛币
1307 个
通用积分
2.5500
学术水平
0 点
热心指数
0 点
信用等级
0 点
经验
1152 点
帖子
96
精华
0
在线时间
13 小时
注册时间
2004-11-2
最后登录
2023-12-26

楼主
9lotus 发表于 2008-8-25 18:43:00 |AI写论文

+2 论坛币
k人 参与回答

经管之家送您一份

应届毕业生专属福利!

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

经管之家联合CDA

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

感谢您参与论坛问题回答

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

+2 论坛币

比如某个数据框包含3个变量,第一列为名字(有重复,如A,A,A,A,B,B,B,B,B,C,C....)A,第二列为日期(也可能有重复,如"2006-10-6","2006-10-7","2006-10-8","2006-10-9","2006-10-7","2006-10-8"...),第三列为收益.现在需要找出名字为B,日期为2006-11-8的这一行,并给出行序号以进一步计算。

哪位大侠能指点迷津?

二维码

扫码加我 拉你入群

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

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

关键词:Dataframe Frame Data Fram FRA 序号 Dataframe

回帖推荐

birdnick 发表于9楼  查看完整内容

 x=strptime(x,format="%Y/%m/%d")这一步你的参数没有用好,应该是,你可以看看 z$x,里面会有一个 "CST",这个我就搞不懂了你 x=as.character(strptime(x,format="%Y/%m/%d"))就可以了

birdnick 发表于4楼  查看完整内容

你用 grep()试一下, 或者a = dataframe();count = 0;cn = 0for(i in 1 : length(a)){if(a=="B" & a=="2006-10-8") {count = count + 1;cn[count] = i;}

birdnick 发表于2楼  查看完整内容

a = dataframe();count = 0for(i in 1 : length(a)){if(a=="B" & a=="2006-10-8") count = count + a}

本帖被以下文库推荐

Do not forget you're just a nobody

沙发
birdnick 发表于 2008-8-25 20:36:00

a = dataframe();count = 0

for(i in 1 : length(a))

{

if(a[i,1]=="B" & a[i,2]=="2006-10-8") count = count + a[i,3]

}

[em01]
已有 1 人评分论坛币 学术水平 热心指数 收起 理由
crystal8832 + 10 + 1 + 1 热心帮助其他会员

总评分: 论坛币 + 10  学术水平 + 1  热心指数 + 1   查看全部评分

藤椅
9lotus 发表于 2008-8-25 22:08:00

感谢赐教!

但其实我需要的的符合条件的行序号,即其他软件包中的第几个观测值.还望大侠再指点

Do not forget you're just a nobody

板凳
birdnick 发表于 2008-8-26 00:11:00

你用 grep()试一下,

或者

a = dataframe();count = 0;cn = 0

for(i in 1 : length(a))

{

if(a[i,1]=="B" & a[i,2]=="2006-10-8") {count = count + 1;cn[count] = i;

}

报纸
bingobingo 在职认证  发表于 2008-8-26 11:16:00
use which() function

地板
birdnick 发表于 2008-8-26 13:13:00

嘿嘿,忘了 ;p

7
9lotus 发表于 2008-8-26 15:33:00

感谢两位热情相助,还有问题

请看下面:

x=c("2006/10/6","2006/10/7","2006/11/2","2006/11/8")
> x=strptime(x,format="%Y/%m/%d")
> y=c("zs","zs","ls","ls")
> r=c(0.12,0.45,-0.2,0.05)
> z=data.frame(x,y,r)
> z
           x  y     r
1 2006-10-06 zs  0.12
2 2006-10-07 zs  0.45
3 2006-11-02 ls -0.20
4 2006-11-08 ls  0.05
> which(z$x=="2006-10-07"&z$y=="zs")
integer(0)
问题出在X的格式上,若

xx=c("2006/10/6","2006/10/7","2006/11/2","2006/11/8")
>
> y=c("zs","zs","ls","ls")
> r=c(0.12,0.45,-0.2,0.05)
> z=data.frame(xx,y,r)
> which(xx=="2006-10-07"&y=="zs")

>2

成功!问题解决.

但xx=="2006-10-07"有什么问题呢?

Do not forget you're just a nobody

8
bingobingo 在职认证  发表于 2008-8-27 14:09:00
S中有专门的date格式数据,具体的你要查阅一下time series analysis一章的帮助手册。否则只能按照字符串的格式进行匹配处理。

9
birdnick 发表于 2008-8-27 14:25:00

 x=strptime(x,format="%Y/%m/%d")
这一步你的参数没有用好,应该是,你可以看看 z$x,里面会有一个 "CST",这个我就搞不懂了

你 x=as.character(strptime(x,format="%Y/%m/%d"))

就可以了

已有 1 人评分论坛币 学术水平 热心指数 收起 理由
crystal8832 + 10 + 1 + 1 热心帮助其他会员

总评分: 论坛币 + 10  学术水平 + 1  热心指数 + 1   查看全部评分

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

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