gpt4 book ai didi

pandas - 如何在style.apply之后显示 Pandas 数据框的截断形式?

转载 作者:行者123 更新时间:2023-12-04 13:38:50 25 4
gpt4 key购买 nike

通常,一个相对较长的数据帧,如

df = pd.DataFrame(np.random.randint(0,10,(100,2)))
df

将在 jupyter notebook 中显示一个截断的形式,如

enter image description here

头、尾、省略号在中间,行列数在最后。
但是,在 style.apply 之后
def highlight_max(x):
return ['background-color: yellow' if v == x.max() else '' for v in x]
df.style.apply(highlight_max)

我们显示了所有行

enter image description here

在style.apply之后是否仍然可以显示数据框的截断形式?

最佳答案

这么简单的事?

def display_df(dataframe, function):
display(dataframe.head().style.apply(function))
display(dataframe.tail().style.apply(function))
print(f'{dataframe.shape[0]} rows x {dataframe.shape[1]} columns')

display_df(df, highlight_max)

输出:

enter image description here

**** 编辑 ****
def display_df(dataframe, function):
display(pd.concat([dataframe.iloc[:5,:],
pd.DataFrame(index=['...'], columns=dataframe.columns),
dataframe.iloc[-5:,:]]).style.apply(function))
print(f'{dataframe.shape[0]} rows x {dataframe.shape[1]} columns')

display_df(df, highlight_max)

输出:

enter image description here

jupyter 预览基本上是这样的:
def display_df(dataframe):
display(pd.concat([dataframe.iloc[:5,:],
pd.DataFrame(index=['...'], columns=dataframe.columns, data={0: '...', 1: '...'}),
dataframe.iloc[-5:,:]]))

但是,如果您尝试应用样式,则会出现错误(TypeError: '>=' not supported between 'int' 和 'str'),因为它正在尝试比较和突出显示字符串值 '...'

关于pandas - 如何在style.apply之后显示 Pandas 数据框的截断形式?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/60137757/

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