pandas将长度不同的list或Series合并成一个dataframe

不同长度的Series和DataFrame合并

# s1为一个DataFrame,s2为一个Series
def expand_columns(s1, s2):
	s1.np.array(s1).tolist()
	data = [(k, ','.join(v)) for k in s2 for v in s1]
	data = pd.DataFrame(data, columns=[s2.name, 's1_tmp_name')
	data_expand = data['s1_tmp_name'].str.split(',', expand=True)
	data = pd.concat([data, data_expand], axis=1)
	data.drop(['s1_tmp_name'], inplace=True)
	data.columns = ('col1', 'col2', 'col3')
	return data
	

不同长度的list合并

ntest = ['a','b']
ltest = [[1,2], [4,5,6]]

data = [(k, v) for k, l in zip(ntest, ltest) for v in l]

print pd.DataFrame(data)
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值