婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

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

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

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

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

它的思路是:

生成一堆單詞,然后把這些表的列索引全部替換為這些單詞,然后調用 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實現豎著拼接、橫著拼接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

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

默認有個參數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橫著拼接

用參數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

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

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

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

巨人網絡通訊聲明:本文標題《使用pandas忽略行列索引,縱向拼接多個dataframe》,本文關鍵詞  使用,pandas,忽略,行列,索引,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《使用pandas忽略行列索引,縱向拼接多個dataframe》相關的同類信息!
  • 本頁收集關于使用pandas忽略行列索引,縱向拼接多個dataframe的相關信息資訊供網民參考!
  • 推薦文章
    主站蜘蛛池模板: 兰州市| 牙克石市| 永兴县| 饶平县| 阿城市| 汕尾市| 阿坝县| 定襄县| 临城县| 芜湖县| 宁化县| 英德市| 沙洋县| 额尔古纳市| 微山县| 宜君县| 大渡口区| 黄浦区| 左贡县| 井陉县| 庆安县| 武城县| 张家川| 车致| 弥渡县| 岳阳市| 东平县| 车险| 芒康县| 乐安县| 赞皇县| 新丰县| 贡山| 沾益县| 巩留县| 阜新市| 祥云县| 象州县| 白朗县| 临朐县| 静安区|