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)
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章