我想在Python中创建一个包含24列(表示24小时)的数据帧,如下所示:
column name 0 1 2 3 ... 24
row 1 0 0 0 0 0
row 2 0 0 0 0 0
row 3 0 0 0 0 0
我想知道如何初始化它?在将来,我可能会添加第4行,所有“0”,如何做到这一点?谢谢,
答案 0 :(得分:10)
这里有一个技巧:当DataFrame(或Series)构造函数传递一个标量作为第一个参数时,该值被传播:
In [11]: pd.DataFrame(0, index=np.arange(1, 4), columns=np.arange(24))
Out[11]:
0 1 2 3 4 5 6 7 8 9 ... 14 15 16 17 18 19 20 21 22 23
1 0 0 0 0 0 0 0 0 0 0 ... 0 0 0 0 0 0 0 0 0 0
2 0 0 0 0 0 0 0 0 0 0 ... 0 0 0 0 0 0 0 0 0 0
3 0 0 0 0 0 0 0 0 0 0 ... 0 0 0 0 0 0 0 0 0 0
[3 rows x 24 columns]
注意:np.arange
是对python范围的愚蠢回答。
答案 1 :(得分:8)
您可以创建一个空的numpy数组,将其转换为数据帧,然后添加标题名称。
import numpy
a = numpy.zeros(shape=(3,24))
df = pd.DataFrame(a,columns=['col1','col2', etc..])
使用
设置行名称 df.set_index(['row1', 'row2', etc..])
如果必须的话。