正文
博客地址:https://www.cnblogs.com/zylyehuo/
开发环境
- anaconda
- 集成环境:集成好了数据分析和机器学习中所需要的全部环境
- 安装目录不可以有中文和特殊符号
- jupyter
- anaconda提供的一个基于浏览器的可视化开发工具
import pandas as pd
import numpy as np
级联操作 -- 对应表格
- pd.concat
- pd.append
- pandas使用pd.concat函数,与np.concatenate函数类似,只是多了一些参数:
- objs
- axis=0
- keys
- join='outer' / 'inner':表示的是级联的方式,outer会将所有的项进行级联(忽略匹配和不匹配),而inner只会将匹配的项级联到一起,不匹配的不级联
- ignore_index=False
匹配级联
df1 = pd.DataFrame(data=np.random.randint(0,100,size=(5,3)),columns=['A','B','C'])
df2 = pd.DataFrame(data=np.random.randint(0,100,size=(5,3)),columns=['A','D','C'])
pd.concat((df1,df2),axis=1) # 行列索引都一致的级联叫做匹配级联
data:image/s3,"s3://crabby-images/ec8f6/ec8f67ab85cc973bbc465929c8eaafad104652ed" alt=""
不匹配级联
- 不匹配指的是级联的维度的索引不一致。例如纵向级联时列索引不一致,横向级联时行索引不一致
- 有2种连接方式:
- 外连接:补NaN(默认模式)
- 内连接:只连接匹配的项
pd.concat((df1,df2),axis=0)
data:image/s3,"s3://crabby-images/6fc17/6fc17d92ddeb9db826a32e0eb2e676bd564ea232" alt=""
内连接
pd.concat((df1,df2),axis=0,join='inner') # inner直把可以级联的级联不能级联不处理
data:image/s3,"s3://crabby-images/7de25/7de257243c216e4a9d65792376243ac7804e7ac6" alt=""
外连接
- 如果想要保留数据的完整性必须使用 outer(外连接)
pd.concat((df1,df2),axis=0,join='outer')
data:image/s3,"s3://crabby-images/392cf/392cf964a882fad4cab5a64bfed735ed9da83185" alt=""
df1.append(df2)
data:image/s3,"s3://crabby-images/6437c/6437c4c1d13f2cb643c08326555410799b3ea35c" alt=""
合并操作 -- 对应数据
- merge与concat的区别在于,merge需要依据某一共同列来进行合并
- 使用pd.merge()合并时,会自动根据两者相同column名称的那一列,作为key来进行合并。
- 注意每一列元素的顺序不要求一致
一对一合并
from pandas import DataFrame
df1 = DataFrame({'employee':['Bob','Jake','Lisa'],
'group':['Accounting','Engineering','Engineering'],
})
df1
data:image/s3,"s3://crabby-images/dd1bb/dd1bba62a9b22ca5fc6b95912998272ce7c7d816" alt=""
df2 = DataFrame({'employee':['Lisa','Bob','Jake'],
'hire_date':[2004,2008,2012],
})
df2
data:image/s3,"s3://crabby-images/aa629/aa62935e4d55fbd647d8dc13e4edac6632b511f9" alt=""
pd.merge(df1,df2,on='employee')
data:image/s3,"s3://crabby-images/3ece7/3ece765b0743f024cd110fb0d26880789dfc1409" alt=""
一对多合并
df3 = DataFrame({
'employee':['Lisa','Jake'],
'group':['Accounting','Engineering'],
'hire_date':[2004,2016]})
df3
data:image/s3,"s3://crabby-images/c0212/c02128735c27b5192d65e5f26e4780c72638dd14" alt=""
df4 = DataFrame({'group':['Accounting','Engineering','Engineering'],
'supervisor':['Carly','Guido','Steve']
})
df4
data:image/s3,"s3://crabby-images/32117/3211775ba123535f38e23f428e142d35aff7667f" alt=""
pd.merge(df3,df4) # on如果不写,默认情况下使用两表中公有的列作为合并条件
data:image/s3,"s3://crabby-images/1c258/1c258b188f1b560c02b9eb20fcdb9972407dcd91" alt=""
多对多合并
df1 = DataFrame({'employee':['Bob','Jake','Lisa'],
'group':['Accounting','Engineering','Engineering']})
df1
data:image/s3,"s3://crabby-images/73f6c/73f6cf0bb687728adaca8dd62632532b6c465eff" alt=""
df5 = DataFrame({'group':['Engineering','Engineering','HR'],
'supervisor':['Carly','Guido','Steve']
})
df5
data:image/s3,"s3://crabby-images/4c6b9/4c6b9ff98b81351d221609eb100b7835758dc0bb" alt=""
pd.merge(df1,df5,how='right')
data:image/s3,"s3://crabby-images/9381b/9381b394ffa99717e615f88632644dde5d399c5f" alt=""
pd.merge(df1,df5,how='left')
data:image/s3,"s3://crabby-images/8cbf6/8cbf628c1b7acaed0c02c374253de6cec3dd025d" alt=""
key的规范化
- 当两张表没有可进行连接的列时,可使用left_on和right_on手动指定merge中左右两边的哪一列列作为连接的列
df1 = DataFrame({'employee':['Bobs','Linda','Bill'],
'group':['Accounting','Product','Marketing'],
'hire_date':[1998,2017,2018]})
df1
data:image/s3,"s3://crabby-images/9c0b5/9c0b5eae225c384c52cab0653ca28daaffcd26c4" alt=""
df5 = DataFrame({'name':['Lisa','Bobs','Bill'],
'hire_dates':[1998,2016,2007]})
df5
data:image/s3,"s3://crabby-images/6d31c/6d31c96bf1fd0265b045cb07fc4b9bcd1c835c41" alt=""
pd.merge(df1,df5,left_on='employee',right_on='name')
data:image/s3,"s3://crabby-images/2bfb1/2bfb1b4a295f4b689fafd15f8029f9056ad0b8bc" alt=""
内合并与外合并
df6 = DataFrame({'name':['Peter','Paul','Mary'],
'food':['fish','beans','bread']}
)
df7 = DataFrame({'name':['Mary','Joseph'],
'drink':['wine','beer']})
df6
data:image/s3,"s3://crabby-images/820cb/820cb6f5d07014e0cb7db442295e9e8dca8865df" alt=""
df7
data:image/s3,"s3://crabby-images/e2806/e28067f49b5dcdfa0e915851aadc37c50137f1ca" alt=""
pd.merge(df6,df7,how='outer')
data:image/s3,"s3://crabby-images/8a37c/8a37c45322ce8183c45d14f0fbc04ff992cbd7a0" alt=""
df6 = DataFrame({'name':['Peter','Paul','Mary'],
'food':['fish','beans','bread']}
)
df7 = DataFrame({'name':['Mary','Joseph'],
'drink':['wine','beer']})
df6
data:image/s3,"s3://crabby-images/1195f/1195f93c649c25ea45812525e19c3edf375f4730" alt=""
df7
data:image/s3,"s3://crabby-images/0756c/0756cac4b2b51d81f79ffddabf88479c11b81260" alt=""
pd.merge(df6,df7,how='inner')
data:image/s3,"s3://crabby-images/85e1b/85e1be100a696ee97a138e4227bae493ee63a42c" alt=""