成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

Python中實現“一行拆多行“和“多行并一行“,你會嗎?

開發 后端
今天粉絲提了下面這樣一個問題,其中一個是"一行拆多行",另外一個是"多行并一行",貌似群友用power query已經解決了。但是基于Python怎么做呢?接著往下看。

[[339021]]

 粉絲提問

今天粉絲提了下面這樣一個問題,其中一個是"一行拆多行",另外一個是"多行并一行",貌似群友用power query已經解決了。但是基于Python怎么做呢?接著往下看。

 

一行拆多行

上面這個問題我會提供兩個思路,供大家選擇,當然肯定是越簡單得越好。每種方法中都有一些好用的技巧,希望大家能夠好好學習。

1)方法一

下方代碼中有很多重要的知識點,需要我們下去好好學習一下,我只提供解題思路,關于每個知識點怎么用,希望大家下去自行研究學習。

  • Pandas.melt()函數的用法;
  • Series.str.split("/",expand=True)中,expand=True參數的用法;
  • Series.sort_values()對文本進行排序;
  • Python中enumerate()函數的用法;

 

  1. import pandas as pd 
  2. # 讀取數據 
  3. df = pd.read_excel("test1.xlsx",sheet_name="Sheet1"
  4. # 將一列炸裂成多列 
  5. df[["類型1","類型2","類型3"]] = df["電影類型"].str.split("/",expand=True
  6. # 選取想要的列 
  7. df_final = df[["電影名","類型1","類型2","類型3"]] 
  8. # 將行轉列 
  9. df_final = df_final.melt(id_vars=["電影名"],value_name="類型"
  10. # 對“電影名”字段進行排序 
  11. df_final = df_final[["電影名","類型"]] 
  12. df_final.sort_values(by="電影名",inplace=True
  13. # 刪除“類型==None”的行 
  14. for index,value in enumerate(df_final["類型"]): 
  15.     if value == None: 
  16.         df_final.drop(df_final.index[index],inplace=True
  17. df_final 

結果如下:

 

2)方法二

上述方法確實復雜,由于我的Pandas版本是0.23.4,因此無法使用explode()方法,進行炸裂操作。在pandas0.25版本的時候,DataFrame中才新增了一個explode()方法,專門用來將一行變多行。

  • Pandas.explode()函數的用法;

 

  1. import pandas as pd 
  2. # 讀取數據 
  3. df = pd.read_excel("test1.xlsx",sheet_name="Sheet1"
  4. # 將一行拆分成列表形式,注意:這里不需要使用expand=True參數 
  5. df["type"] = df["電影類型"].str.split("/"
  6. # 直接炸裂指定列 
  7. df.explode("type"

結果如下:

 

 

 

 

多行并一行這里沒有使用什么特別的知識,好好的理解Pandas中分組聚合應用某個函數,即可輕松解決這個問題。

 

  1. import pandas as pd 
  2. # 讀取數據 
  3. df = pd.read_excel("test1.xlsx",sheet_name="Sheet2"
  4. # 分組聚合,應用某個函數 
  5. def func(df): 
  6.     return ','.join(df.values
  7. df = df.groupby(by='電影名').agg(func).reset_index() 
  8. df 

結果如下:

 

 

責任編輯:華軒 來源: 數據分析與統計學之美
相關推薦

2016-12-02 08:53:18

Python一行代碼

2022-04-09 09:11:33

Python

2015-07-20 17:17:41

SQL Server

2020-08-19 10:30:25

代碼Python多線程

2011-08-25 09:17:31

Java調用存儲過程返回一行或多行結果集

2022-02-23 14:37:48

代碼Pythonbug

2024-08-08 09:15:08

SQL代碼復制表

2017-04-13 19:20:18

Python代碼并行任務

2021-11-02 16:25:41

Python代碼技巧

2021-05-28 07:39:17

SQL代碼操作

2014-02-12 13:43:50

代碼并行任務

2017-04-05 11:10:23

Javascript代碼前端

2024-11-08 17:22:22

2024-07-04 00:30:17

2024-08-01 09:57:17

DELETE死鎖工具

2021-04-22 11:27:24

Python命令水印

2020-08-12 14:54:00

Python代碼開發

2020-09-28 12:34:38

Python代碼開發

2022-05-13 09:36:06

Python水印命令

2021-10-19 17:52:16

Git命令算數
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 亚洲综合国产 | 日本在线免费看最新的电影 | 久久大陆 | 亚洲欧洲激情 | 免费网站在线 | 国产成人99久久亚洲综合精品 | 台湾a级理论片在线观看 | 国产精品久久久久久久久久 | 老外黄色一级片 | 中文字幕在线电影观看 | 国产高清久久久 | 日韩电影一区 | 三极网站 | 91色网站| 欧美激情一区二区三区 | 成人精品一区二区三区中文字幕 | 一区二区在线免费观看 | 看毛片的网站 | 精品欧美一区二区三区久久久 | 亚洲精品自在在线观看 | 色橹橹欧美在线观看视频高清 | 欧美一级大片 | 国内自拍偷拍一区 | 99免费 | 日本不卡免费新一二三区 | 九九热这里只有精品6 | 午夜欧美 | 一区二区精品视频 | 国产精品美女一区二区三区 | 久久精品国产免费高清 | 日日干夜夜操 | 草草视频在线播放 | 国产在线观看不卡一区二区三区 | 国产精品视频综合 | 免费午夜视频在线观看 | av电影一区二区 | 亚洲视频一区 | 久久大陆| 日本在线一二 | 亚洲免费在线 | 久久成人一区二区三区 |