濮阳杆衣贸易有限公司

主頁 > 知識庫 > 使用pandas忽略行列索引,縱向拼接多個dataframe

使用pandas忽略行列索引,縱向拼接多個dataframe

熱門標簽:千陽自動外呼系統(tǒng) 原裝電話機器人 工廠智能電話機器人 平頂山外呼系統(tǒng)免費 在哪里辦理400電話號碼 400電話申請服務商選什么 江蘇客服外呼系統(tǒng)廠家 清遠360地圖標注方法 西藏智能外呼系統(tǒng)五星服務

從wind上面搞到一批股票數(shù)據(jù)后發(fā)現(xiàn):本來是一個類型的數(shù)據(jù),但是由于季度不同,列名也不同,導致使用pandas合并多個報表的時候總是出現(xiàn)一大堆NaN,所以這里我寫了一個函數(shù),專門針對這樣的表

它的思路是:

生成一堆單詞,然后把這些表的列索引全部替換為這些單詞,然后調(diào)用 pd.concat() 把這些dataframe全部合并后再把列索引改回來,當然,這里也可以手動指定列索引。

使用方法見代碼的最后一行,傳入一個dataframe的list就可以了。

import pandas as pd
from random import Random 
 
# 隨機生成一堆單詞作為公共的列名
def random_list(random_str_count, randomlengtd=6):
 result_list = []
 random = Random()
 chars = "qwertyuiopasdfghjklzxcvbnm"
 for str_count in range(random_str_count):
 ranstr = ""
 lengtd = len(chars) - 1
 for str_lengtd in range(randomlengtd):
 ranstr += chars[random.randint(0, lengtd)]
 result_list.append(ranstr)
 return result_list 
 
def combine_as_data_location(pd_list, columns=''):
 if not pd_list:
 return None
 old_columns = pd_list[0].columns
 if columns:
 new_columns = columns
 else:
 new_columns = random_list(pd_list[0].shape[1])
 for data_df in pd_list:
 # data is pandas Dataframe
 data_df.columns = new_columns
 result_df = pd.concat(pd_list, ignore_index=True)
 if columns:
 return result_df
 else:
 result_df.columns = old_columns
 return result_df 
result_df = combine_as_data_location([df1,df2,df3])

補充:pandas.concat實現(xiàn)豎著拼接、橫著拼接DataFrame

1、concat豎著拼接(默認的豎著,axis=0)

話不多說,直接看例子:

import pandas as pd
df1=pd.DataFrame([10,12,13])
df2=pd.DataFrame([22,33,44,55])
df3=pd.DataFrame([90,94])

df1

0
0 10
1 12
2 13

df2

0
0 22
1 33
2 44
3 55

df3

0
0 90
1 94
res= pd.concat([df1,df2,df3])
res
0
0 10
1 12
2 13
0 22
1 33
2 44
3 55
0 90
1 94

如果要生成新索引,忽略原來索引怎么辦?

默認有個參數(shù)ignore_index= False,將其值改為True:

res2= pd.concat([df1,df2,df3], ignore_index=True)
res2
0
0 10
1 12
2 13
3 22
4 33
5 44
6 55
7 90
8 94

2、concat橫著拼接

用參數(shù)axis= 1,看例子:

res_heng= pd.concat([df1,df2,df3], axis=1)
res_heng
0 0 0
0 10.0 22 90.0
1 12.0 33 94.0
2 13.0 44 NaN
3 NaN 55 NaN

以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。如有錯誤或未考慮完全的地方,望不吝賜教。

您可能感興趣的文章:
  • Pandas實現(xiàn)Dataframe的重排和旋轉(zhuǎn)
  • Pandas實現(xiàn)Dataframe的合并
  • pandas中DataFrame數(shù)據(jù)合并連接(merge、join、concat)
  • 教你漂亮打印Pandas DataFrames和Series
  • pandas中DataFrame檢測重復值的實現(xiàn)
  • Pandas.DataFrame轉(zhuǎn)置的實現(xiàn)
  • Pandas中DataFrame交換列順序的方法實現(xiàn)
  • 詳解pandas中利用DataFrame對象的.loc[]、.iloc[]方法抽取數(shù)據(jù)
  • Pandas中兩個dataframe的交集和差集的示例代碼
  • Pandas DataFrame求差集的示例代碼
  • 淺談pandas dataframe對除數(shù)是零的處理
  • Pandas中DataFrame數(shù)據(jù)刪除詳情

標簽:隨州 白城 安慶 天水 錦州 日照 西安 股票

巨人網(wǎng)絡通訊聲明:本文標題《使用pandas忽略行列索引,縱向拼接多個dataframe》,本文關(guān)鍵詞  使用,pandas,忽略,行列,索引,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡,涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《使用pandas忽略行列索引,縱向拼接多個dataframe》相關(guān)的同類信息!
  • 本頁收集關(guān)于使用pandas忽略行列索引,縱向拼接多個dataframe的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    梓潼县| 江都市| 三门县| 泾源县| 高州市| 蒙山县| 莱芜市| 鸡泽县| 平舆县| 锡林郭勒盟| 望城县| 鸡东县| 宝鸡市| 鄂托克前旗| 临猗县| 开平市| 津南区| 休宁县| 丰顺县| 安宁市| 保亭| 化州市| 东光县| 冕宁县| 博兴县| 宁阳县| 漳浦县| 山东省| 繁峙县| 赤峰市| 东丰县| 会理县| 昌都县| 平定县| 万州区| 建湖县| 商丘市| 大埔县| 同德县| 青海省| 黄龙县|