pandas - IPython Notebookセルの複数出力




pandas dataframe excel writer (3)

IPython Notebookは、セル内の最後の戻り値のみを表示します。 あなたの場合の最も簡単な解決策は、2つのセルを使用することです。

本当に必要なセルが1つだけの場合は、次のような ハックを 実行できます。

class A:
    def _repr_html_(self):
        return salaries.head()._repr_html_() + '</br>' + teams.head()._repr_html_()

A()

これが頻繁に必要な場合は、関数にしてください:

def show_two_heads(df1, df2, n=5):
    class A:
        def _repr_html_(self):
            return df1.head(n)._repr_html_() + '</br>' + df2.head(n)._repr_html_()
    return A()

使用法:

show_two_heads(salaries, teams)

3つ以上のヘッドのバージョン:

def show_many_heads(*dfs, n=5):
    class A:
        def _repr_html_(self):
            return  '</br>'.join(df.head(n)._repr_html_() for df in dfs) 
    return A()

使用法:

show_many_heads(salaries, teams, df1, df2)

私はこのセルをIPython Notebookで実行しています:

# salaries and teams are Pandas dataframe
salaries.head()
teams.head()

その結果、 salariesteams の両方ではなく、 teams データフレームの出力しか取得できません。 salaries.head() を実行すると、 salaries data-frameの結果が salaries ますが、両方のステートメントを実行すると、 teams.head() 出力が teams.head() ます。 どうすれば修正できますか?


より簡単な方法:

from IPython.core.interactiveshell import InteractiveShell
InteractiveShell.ast_node_interactivity = "all"

「ディスプレイ」と繰り返し入力する必要がなくなります

セルにこれが含まれているとしましょう:

from IPython.core.interactiveshell import InteractiveShell
InteractiveShell.ast_node_interactivity = "all"

a = 1
b = 2

a
b

出力は次のようになります。

Out[1]: 1
Out[1]: 2

IPython.display.display を使用する場合:

from IPython.display import display

a = 1
b = 2

display(a)
display(b)

出力は次のとおりです。

1
2

同じことですが、 Out[n] 部分はありません。


display コマンドを試しましたか?

from IPython.display import display
display(salaries.head())
display(teams.head())




ipython-notebook