我有一个由数百列组成的数据框架,我需要看到所有的列名。

我做了什么:

In[37]:
data_all2.columns

输出结果为:

Out[37]:
Index(['customer_id', 'incoming', 'outgoing', 'awan', 'bank', 'family', 'food',
       'government', 'internet', 'isipulsa',
       ...
       'overdue_3months_feature78', 'overdue_3months_feature79',
       'overdue_3months_feature80', 'overdue_3months_feature81',
       'overdue_3months_feature82', 'overdue_3months_feature83',
       'overdue_3months_feature84', 'overdue_3months_feature85',
       'overdue_3months_feature86', 'loan_overdue_3months_total_y'],
      dtype='object', length=102)

我如何显示所有列,而不是一个截断列表?


当前回答

我找到的最简单的方法就是

list(df.columns)

就我个人而言,我不想改变全局变量,我不是经常想看到所有的列名。

其他回答

我的去打印每一列在我的控制台是:

pandas.set_option('display.expand_frame_repr', False)

如果你只是想看到所有的列,你可以做一些这样的事情作为快速修复

cols = data_all2.columns

现在cols将表现为一个可以被索引的迭代变量。例如

cols[11:20]

这不是一个传统的答案,但我猜您可以转置数据框架来查看行而不是列。我使用这个方法是因为我发现看行比看列更“直观”:

data_all2.T

这应该可以让您查看所有行。这个动作不是永久的,它只是让你查看数据帧的转置版本。

如果行仍然被截断,只需使用print(data_all2.T)查看所有内容。

一个快速而简单的解决方案是将其转换为字符串

print('\t'.join(data_all2.columns))

会导致它们全部被打印出来,被制表符隔开 当然,请注意,102个名字都相当长,因此阅读起来有点困难

我知道这是重复,但我总是以复制粘贴和修改YOLO的答案结束:

pd.set_option('display.max_columns', 500)
pd.set_option('display.max_rows', 500)