gpt4 book ai didi

r - 如何通过根据名称而不是索引选择一系列列和行来切片数据框?

转载 作者:行者123 更新时间:2023-12-04 13:37:33 24 4
gpt4 key购买 nike

这是我问的问题的后续问题here .在那里我学到了 a) 如何对列执行此操作(见下文)和 b) 行和列的选择在 R 中的处理方式似乎完全不同,这意味着我不能对行使用相同的方法。

所以假设我有一个像这样的 Pandas 数据框:

import pandas as pd
import numpy as np

df = pd.DataFrame(np.random.randint(10, size=(6, 6)),
columns=['c' + str(i) for i in range(6)],
index=["r" + str(i) for i in range(6)])

c0 c1 c2 c3 c4 c5
r0 4 2 3 9 9 0
r1 9 0 8 1 7 5
r2 2 6 7 5 4 7
r3 6 9 9 1 3 4
r4 1 1 1 3 0 3
r5 0 8 5 8 2 9

然后我可以轻松地按名称选择行和列,如下所示:
print df.loc['r3':'r5', 'c1':'c4']

返回
    c1  c2  c3  c4
r3 9 9 1 3
r4 1 1 3 0
r5 8 5 8 2

我将如何在 R 中做到这一点?给定这样的数据框
df <- data.frame(c1=1:6, c2=2:7, c3=3:8, c4=4:9, c5=5:10, c6=6:11)
rownames(df) <- c('r1', 'r2', 'r3', 'r4', 'r5', 'r6')

c1 c2 c3 c4 c5 c6
r1 1 2 3 4 5 6
r2 2 3 4 5 6 7
r3 3 4 5 6 7 8
r4 4 5 6 7 8 9
r5 5 6 7 8 9 10
r6 6 7 8 9 10 11

显然,如果我知道我想要的行/列的索引,我可以简单地做:
df[3:5, 1:4]

但我可能会在整个分析过程中删除行/列,以便我宁愿按名称而不是按索引进行选择。从上面的链接中,我了解到对于列,以下内容可以工作:
subset(df, select=c1:c4)

返回
  c1 c2 c3 c4
r1 1 2 3 4
r2 2 3 4 5
r3 3 4 5 6
r4 4 5 6 7
r5 5 6 7 8
r6 6 7 8 9

但是我怎么能同时按名称选择一系列行呢?

在这种特殊情况下,我当然可以使用 grep但是具有任意名称的列呢?

我不想使用
df[c('r3', 'r4' 'r5'), c('c1','c2', 'c3', 'c4')]

但一个实际的切片。

最佳答案

您可以使用 which()rownames :

subset(df[which(rownames(df)=='r3'):which(rownames(df)=='r5'),], select=c1:c4)


c1 c2 c3 c4
r3 3 4 5 6
r4 4 5 6 7
r5 5 6 7 8

关于r - 如何通过根据名称而不是索引选择一系列列和行来切片数据框?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/37715085/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com