首页 > 解决方案 > 从 python 帮助中提取示例到 ipython 会话中

问题描述

ipython我可以运行诸如

import pandas as pd
pd.DataFrame.join?

并查看帮助DataFrame

帮助文件的末尾经常有例子,比如

Another option to join using the key columns is to use the `on`
parameter. DataFrame.join always uses `other`'s index but we can use
any column in `df`. This method preserves the original DataFrame's
index in the result.

>>> df.join(other.set_index('key'), on='key')
  key   A    B
0  K0  A0   B0
1  K1  A1   B1
2  K2  A2   B2
3  K3  A3  NaN
4  K4  A4  NaN
5  K5  A5  NaN

我想知道是否有一种快速的方法可以将这些示例提取到当前会话中,以便我可以进一步研究它们,或者我是否必须从帮助文件中复制粘贴(然后调整)代码。

标签: pythonpython-3.xpandasipythonmanpage

解决方案


对于通用 Python 示例,复制示例然后粘贴即可;IPython 足够聪明,可以理解 Python>>>...前缀,以及它自己的前缀格式。请参阅IPython 手册中的粘贴以 Python 或 IPython 提示开头的代码。

我正在从此处的文档中复制前两个示例:

In [1]: import pandas as pd

In [2]: pd.DataFrame.join?

In [3]: >>> df = pd.DataFrame({'key': ['K0', 'K1', 'K2', 'K3', 'K4', 'K5'],
   ...: ...                    'A': ['A0', 'A1', 'A2', 'A3', 'A4', 'A5']})

In [4]: df
Out[4]:
  key   A
0  K0  A0
1  K1  A1
2  K2  A2
3  K3  A3
4  K4  A4
5  K5  A5

In [5]: >>> other = pd.DataFrame({'key': ['K0', 'K1', 'K2'],
    ...: ...                       'B': ['B0', 'B1', 'B2']})

你也可以使用%paste终端魔法命令让 IPython 做同样的事情;此命令直接从剪贴板中提取数据。

在这里,我将第三个示例放到剪贴板上:

In [6]: %paste
>>> df.set_index('key').join(other.set_index('key'))
## -- End pasted text --
Out[6]:
      A    B
key
K0   A0   B0
K1   A1   B1
K2   A2   B2
K3   A3  NaN
K4   A4  NaN
K5   A5  NaN

还有一个%cpaste魔术命令,它会提示您将 Python 代码粘贴到其中。您可以多次这样做(也许从不同的部分),直到您--在一行上单独输入双破折号。这确实需要您将示例排列在另一个位置以从中复制,或者您使用剪贴板来回忆以前的条目。

您也可以只复制df数据框输出,并让 Pandas 从剪贴板中读取它,使用pandas.read_clipboard()函数;从列开始复制;这是文档中显示的最终数据帧输出:

In [7]: pd.DataFrame.join?

In [8]: pd.read_clipboard('\s\s+')
Out[8]:
  key   A    B
0  K0  A0   B0
1  K1  A1   B1
2  K2  A2   B2
3  K3  A3  NaN
4  K4  A4  NaN
5  K5  A5  NaN

我使用\s\s+而不是默认的\s+;它更健壮,因为它可以让您接受其中包含单个空格的列名。


推荐阅读