我尝试使用以下代码创建 Dataframe df:
import numpy as np
import pandas as pd
index = [0,1,2,3,4,5]
s = pd.Series([1,2,3,4,5,6],index= index)
t = pd.Series([2,4,6,8,10,12],index= index)
df = pd.DataFrame(s,columns = ["MUL1"])
df["MUL2"] =t
print df
MUL1 MUL2
0 1 2
1 2 4
2 3 6
3 4 8
4 5 10
5 6 12
在尝试使用下面的语法创建相同的 Dataframe 时,我得到了一个wierd输出。
df = pd.DataFrame([s,t],columns = ["MUL1","MUL2"])
print df
MUL1 MUL2
0 NaN NaN
1 NaN NaN
请解释为什么当两个系列都不为空时,NaN显示在数据框中,以及为什么只有两行显示而其余的都不显示。
还提供了创建数据框架的正确方法,与上面提到的方法相同,即在pandas DataFrame方法中使用columns参数。
4条答案
按热度按时间ohtdti5x1#
正确的方法之一是将包含这些序列的输入列表中的数组数据堆叠到列中-
在后台,堆栈创建一个2D数组,然后将其转换为 Dataframe 。这是堆叠阵列的样子-
cgyqldqp2#
如果删除列参数,则获取:
然后定义列-如果列不存在,则获取NaNs列:
最好使用
dictionary
:如果需要更改列顺序,则添加列参数:
更多信息在dataframe文档中。
concat
-DataFrame
构造函数的另一个解决方案是不必要的:pbgvytdp3#
pandas.DataFrame接受参数data,该参数可以是ndarray、iterable、dict或dataframe类型。
如果你传入一个列表,它会假设每个成员都是一行。示例:
您得到的是
NaN
,因为它需要index = [0,1]
,但您给出的是[0,1,2,3,4,5]
要得到你想要的形状,首先转置数据:
如何创建pandas数据框
输出:
daupos2t4#
显示NaN值是因为您尝试使用2行的2x6数组创建数据框(s,t)和6列(每个系列的值),但是,您定义了一个具有2列[“MUL1”,“MUL2”]和2行[s,t]的 Dataframe ,因此输出将是一个2x2数组,由于您有6个值而不是2个值,因此没有正确的信息(2列通过,但通过的数据有6个值)。解决这个问题的一种方法是转置序列,这样你就有了正确的输出。
对于这种情况,我编写代码的方式如下:
输出:
同样的结果将是创建2x6数组(称为“行”)并转置它:
使用的Python和库版本:
我知道这是一个古老的主题,但我希望这对某人有用。