国产片侵犯亲女视频播放_亚洲精品二区_在线免费国产视频_欧美精品一区二区三区在线_少妇久久久_在线观看av不卡

腳本之家,腳本語言編程技術及教程分享平臺!
分類導航

Python|VBS|Ruby|Lua|perl|VBA|Golang|PowerShell|Erlang|autoit|Dos|bat|

服務器之家 - 腳本之家 - Python - pandas dataframe 中的explode函數用法詳解

pandas dataframe 中的explode函數用法詳解

2020-05-19 09:57Sinsa_SI Python

這篇文章主要介紹了pandas dataframe 中的explode函數用法詳解,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧

在使用 pandas 進行數據分析的過程中,我們常常會遇到將一行數據展開成多行的需求,多么希望能有一個類似于 hive sql 中的 explode 函數。

這個函數如下:

Code

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
# !/usr/bin/env python
# -*- coding:utf-8 -*-
# create on 18/4/13
import pandas as pd
 
def dataframe_explode(dataframe, fieldname):
 temp_fieldname = fieldname + '_made_tuple_'
 dataframe[temp_fieldname] = dataframe[fieldname].apply(tuple
 list_of_dataframes = []
 for values in dataframe[temp_fieldname].unique().tolist():
  list_of_dataframes.append(pd.DataFrame({
   temp_fieldname: [values] * len(values),
   fieldname: list(values),
  }))
 dataframe = dataframe[list(set(dataframe.columns) - set([fieldname]))].merge(pd.concat(list_of_dataframes), how='left', on=temp_fieldname)
 del dataframe[temp_fieldname]
 return dataframe
 
df = pd.DataFrame({'listcol':[[1,2,3],[4,5,6]], "aa": [222,333]})
df = dataframe_explode(df, "listcol")

Description

將 dataframe 按照某一指定列進行展開,使得原來的每一行展開成一行或多行。( 注:該列可迭代, 例如list, tuple, set)

補充知識:Pandas列中的字典/列表拆分為單獨的列

我就廢話不多說了,大家還是直接看代碼吧

?
1
2
3
4
5
6
7
[1] df
Station ID  Pollutants
8809   {"a": "46", "b": "3", "c": "12"}
8810   {"a": "36", "b": "5", "c": "8"}
8811   {"b": "2", "c": "7"}
8812   {"c": "11"}
8813   {"a": "82", "c": "15"}

Method 1:

step 1: convert the Pollutants column to Pandas dataframe series

?
1
2
3
4
5
6
7
8
9
df_pol_ps = data_df['Pollutants'].apply(pd.Series)
 
df_pol_ps:
 a b c
0 46 3 12
1 36 5 8
2 NaN 2 7
3 NaN NaN 11
4 82 NaN 15

step 2: concat columns a, b, c and drop/remove the Pollutants

?
1
2
3
4
5
6
7
8
9
df_final = pd.concat([df, df_pol_ps], axis = 1).drop('Pollutants', axis = 1)
 
df_final:
 StationID a b c
0 8809 46 3 12
1 8810 36 5 8
2 8811 NaN 2 7
3 8812 NaN NaN 11
4 8813 82 NaN 15

Method 2:

?
1
2
3
4
5
6
7
8
9
df_final = pd.concat([df, df['Pollutants'].apply(pd.Series)], axis = 1).drop('Pollutants', axis = 1)
 
df_final:
 StationID a b c
0 8809 46 3 12
1 8810 36 5 8
2 8811 NaN 2 7
3 8812 NaN NaN 11
4 8813 82 NaN 15

以上這篇pandas dataframe 中的explode函數用法詳解就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持服務器之家。

原文鏈接:https://blog.csdn.net/Sinsa110/article/details/85260302

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 在线中文字幕视频 | 日本色综合| 久久综合九色综合欧美狠狠 | 日韩成年网站 | 久9re热视频这里只有精品 | 日韩精品视频一区二区三区 | 日韩综合网| 国产成人精品一区二区三区 | 国产免费亚洲 | 欧美精品理论片大全 | 狠狠久久综合 | 色婷婷精品国产一区二区三区 | a在线观看 | 日韩在线视频播放 | 国产馆| 国产精品久久国产精品 | 黄网免费看 | 欧美一区二区 | 蜜桃成人| 日韩欧美在线一区 | 色av综合 | 懂色av成人一区二区三区 | 午夜欧美一区二区三区在线播放 | 国产精品久久久久久久久久久久 | 青青草免费在线 | 国产亚洲精品美女久久久久久久久久 | 久久成人久久爱 | 久久精品99国产精品日本 | 久久精品亚洲国产 | 中文字幕永久第一页 | 国产看片网站 | 久久久一二三 | 亚洲男人天堂2018 | 亚洲欧美视频在线播放 | 99成人在线| 6080yy午夜一二三区久久 | 亚洲在线视频 | 亚洲欧美成人a毛片 | 欧美,日韩,国产精品免费观看 | 黑人一区 | 日韩精品视频一区二区三区 |