首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何在python中从rpy2中的R数据中选择列?

如何在python中从rpy2中的R数据中选择列?
EN

Stack Overflow用户
提问于 2015-07-19 02:37:19
回答 3查看 1.7K关注 0票数 7

我在python中有一个rpy2中的dataframe,我想从它中提取列。这个R码的rpy2等效值是什么?

df[,c("colA", "colC")]

这样可以得到第一列:

mydf.rx(1)

但是我怎样才能拉出一组列,例如第一、第三和第五列?

mydf.rx([1,3,5])

不管用。以下方面也没有:

mydf.rx(rpy2.robjects.r.c([1,3,5]))

EN

回答 3

Stack Overflow用户

回答已采纳

发布于 2015-07-19 03:08:12

我认为答案是:

代码语言:javascript
复制
# cols to select
c = rpy2.robjects.IntVector((1,3))
# selection from df
mydf.rx(True, c)
票数 2
EN

Stack Overflow用户

发布于 2015-07-19 03:36:54

或者,您可以将R数据框架传递到Python熊猫数据框架中,并将得到的1、3、5列的子集:

代码语言:javascript
复制
#!/usr/bin/python
import rpy2
import rpy2.robjects as ro
import pandas as pd
import pandas.rpy.common as com

# SOURCE R SCRIPT INSIDE PYTHON 
ro.r.source('C:\\Path\To\R script.R') 

# DEFINE PYTHON DF AS R DF
pydf = com.load_data('rdf')
cols = pydf[[1,3,5]]
票数 5
EN

Stack Overflow用户

发布于 2017-10-18 07:36:38

我发现最好的方法就是做这件简单的事情:

代码语言:javascript
复制
from rpy2.robjects.packages import importr
from rpy2.robjects import pandas2ri
import rpy2.robjects as robjects

dataframe = robjects.r('data.frame')
df_rpy2 = dataframe([1,2,],[5,6])
df_pd = pd.DataFrame({'A': [1,2], 'B': [5,6]})

base = importr('base') #Creates an instance of R's base package 
pandas2ri.activate() #Converts any pandas dataframe to R equivalent

base.colnames(df_pd) #Finds the column names of the dataframe df_pd 
base.colnames(df_rpy2) #Finds the column names of the dataframe df_rpy2

产出如下:

代码语言:javascript
复制
R object with classes: ('character',) mapped to:
<StrVector - Python:0x7fa3504d3048 / R:0x10f65ac0>
['X1L', 'X2L', 'X5L', 'X6L']

R object with classes: ('character',) mapped to:
<StrVector - Python:0x7fa352493548 / R:0x103b6e40>
['A', 'B']

这对于使用熊猫和rpy2创建的数据集都有效。希望这能有所帮助!

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/31497479

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档