pandas - RMagic、IPython 和摘要信息

标签 pandas ipython rpy2 ipython-notebook

按照这里的例子

http://www.randalolson.com/2013/01/14/filling-in-pythons-gaps-in-statistics-packages-with-rmagic/

我在 IPython 笔记本中找到的不同数据集上尝试了相同的方法。

https://github.com/burakbayramli/kod/blob/master/delltest/dell.tgz

from pandas import *
orders = read_csv("dell.csv",sep=",")
%load_ext rmagic
%R -i orders print(summary(orders))

我得到
     Length Class  Mode
[1,] 25     -none- list
[2,] 25     -none- list
[3,] 25     -none- list
..

然而在 R 中相同
data <- read.csv ("dell.csv",header=TRUE,sep=",")
print (summary(data))

给我正确的摘要信息。
      rank        per_customer_count total_total_amount    orderid     
 Min.   : 1.000   Min.   : 1.000     Min.   :    0.14   Min.   :    1  
 1st Qu.: 2.000   1st Qu.: 6.000     1st Qu.:  866.11   1st Qu.: 2964  
 Median : 4.000   Median : 8.000     Median : 1764.08   Median : 5980  
 Mean   : 4.997   Mean   : 9.426     Mean   : 2004.95   Mean   : 5987  
 3rd Qu.: 7.000   3rd Qu.:12.000     3rd Qu.: 2856.06   3rd Qu.: 9004  
 ...

有任何想法吗?

最佳答案

我快速浏览了一下,似乎在许多情况下 ipython 魔术
没有得到正确的转换。我必须就 rmagic 和他们联系
更神奇。

同时,您应该能够从下面的代码片段中编写出您需要的内容:

import pandas
orders = pandas.read_csv("dell.csv", sep=",")
%load_ext rmagic

import rpy2.robjects
d = dict()
for i, (k,v) in enumerate(orders.iteritems()):
    print("%s (type: %s - %i/%i)" %(k, v.dtype.kind, i, orders.shape[1]))
    if v.dtype.kind == 'O':
      v = rpy2.robjects.vectors.StrVector(v)
    d[k] = rpy2.robjects.conversion.py2ri(v)
df = rpy2.robjects.DataFrame(d)

def print_rsummary(x):
    print(rpy2.robjects.baseenv['summary'](x))

print_rsummary(df)

关于pandas - RMagic、IPython 和摘要信息,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/14356577/

相关文章:

Python:在 Pandas 中进行多列聚合

Python:快速将 7 GB 文本文件加载到 unicode 字符串中

python - 从 rpy2.robjects 导入时出现问题

python - 更新字典值时应用并行化

python - 尝试从 Pandas Dataframe 创建条形图。特定于月份的图表

python - OpenCV imshow 函数在 jupyter notebook 中显示黑色图像

python - 使用 rpy2 从 Python 调用 R 库 DirichletReg

python - 尝试使用 rpy2 模块从 Python 脚本调用 R - 帮助设置 R 主目录?

python - 按行元素分组并转置 Pandas 数据框

python - 在 IPython Notebooks 之间共享数据