pandas:ValueError: arrays must all be same length

在尝试将字典转换为pandas DataFrame时遇到ValueError,因为各列的长度不一致。通过改变数据结构,将所有key作为一列,所有values作为另一列,可以避免长度限制问题。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

在将dict转化为dataframe的过程中出现ValueError: arrays must all be same length

错误示例:

d={ 'NUM' : range(3),
    'C' : ['c1','c2','c3'],
    'D' : ['d1','d2','d3','d4'],
    'E' : ['e1','e2','e3'],
    'B' : ['b1','b2','b3']}

def newdf():
    global d
    df = pd.DataFrame(d)
    return df

df=newdf()
df

这是因为使用dataframe(dict) 构建dataframe时,每个key会变成一个column,list-like values会变为行,每个values中的list长度不一致就会出现这个错误。
但,如果,我想换一种方式构建呢,例如所有key作为一个column,所有values作为另一个column,这样list的长度就没必要保持一致了。在构建dataframe时,没有axis参数来指定方向,所以我用了以下方法:

k=list(d.keys())
v=list(d.values())
df=pd.DataFrame(list(zip(k,v)),columns=['k','v'])
df

output:

k   v
0   NUM (0, 1, 2)
1   C   [c1, c2, c3]
2   D   [d1, d2, d3]
3   E   [e1, e2, e3]
4   B   [b1, b2, b3]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值