앞서 몇 가지 기본 작업을 수행하기 위해 pandas를 사용했습니다. 다음으로 데이터 작업에 대해 자세히 알아봅니다.
데이터 정리는 항상 데이터 분석에서 매우 중요한 부분이었습니다.
데이터 병합
Pandas에서는 병합을 통해 데이터를 병합할 수 있습니다.
import numpy as np import pandas as pd data1 = pd.DataFrame({'level':['a','b','c','d'], 'numeber':[1,3,5,7]}) data2=pd.DataFrame({'level':['a','b','c','e'], 'numeber':[2,3,6,10]}) print(data1)
결과는 다음과 같습니다.
print(data2)
결과는
print(pd.merge(data1,data2))
결과는
data1과 data2에서 동일한 레이블에 사용된 필드가 표시되고 다른 필드는 삭제되는 것을 볼 수 있는데, 이는 SQL의 내부 조인 연결 연산과 동일합니다.
그 외에도 How라는 키워드로 표현되는 Outer, Ringt, Left 등의 연결 방식이 있습니다.
data3 = pd.DataFrame({'level1':['a','b','c','d'], 'numeber1':[1,3,5,7]}) data4=pd.DataFrame({'level2':['a','b','c','e'], 'numeber2':[2,3,6,10]}) print(pd.merge(data3,data4,left_on='level1',right_on='level2'))
결과는 다음과 같습니다.
두 데이터 프레임 모두에 열이 있는 경우 이름이 다른 경우 letf_on 및 right_on 두 매개변수를 지정하여 데이터를 함께 연결할 수 있습니다.
print(pd.merge(data3,data4,left_on='level1',right_on='level2',how='left'))
결과는 다음과 같습니다.
기타 상세 매개변수 설명
겹치는 데이터 병합
가끔 우리는 병합해야 하는 데이터가 겹치는 경우에는comebine_first 함수를 사용할 수 있습니다.
data3 = pd.DataFrame({'level':['a','b','c','d'], 'numeber1':[1,3,5,np.nan]}) data4=pd.DataFrame({'level':['a','b','c','e'], 'numeber2':[2,np.nan,6,10]}) print(data3.combine_first(data4))
결과는 다음과 같습니다.
동일한 태그를 볼 수 있습니다. data3의 내용이 먼저 표시됩니다. 데이터 프레임의 특정 데이터가 누락되면 다른 데이터 프레임의 요소가 채워집니다.
여기서 사용법은 np.where(isnull)와 유사합니다. (a),b,a)
데이터 재구성 및 축 회전
이 내용은 이전 Pandas 기사에서 언급했습니다. 데이터 재구성은 reshape 함수를 주로 사용하고, 회전은 unstack, stack 함수를 주로 사용합니다.
data=pd.DataFrame(np.arange(12).reshape(3,4), columns=['a','b','c','d'], index=['wang','li','zhang']) print(data)
결과는 다음과 같습니다.
print(data.unstack())
결과는 다음과 같습니다.
데이터 변환
중복 데이터 행 제거
data=pd.DataFrame({'a':[1,3,3,4], 'b':[1,3,3,5]}) print(data)
결과는 다음과 같습니다.
print(data.duplicated())
The 결과는
세 번째 행이 두 번째 행의 데이터를 반복하는 것을 볼 수 있으므로 표시된 결과는 True입니다
另外用drop_duplicates方法可以去除重复行
print(data.drop_duplicates())
结果为:
替换值
除了使用我们上一篇文章中提到的fillna的方法外,还可以用replace方法,而且更简单快捷
data=pd.DataFrame({'a':[1,3,3,4], 'b':[1,3,3,5]}) print(data.replace(1,2))
结果为:
多个数据一起换
print(data.replace([1,4],np.nan))
数据分段
data=[11,15,18,20,25,26,27,24] bins=[15,20,25] print(data) print(pd.cut(data,bins))
结果为:
[11, 15, 18, 20, 25, 26, 27, 24][NaN, NaN, (15, 20], (15, 20], (20, 25], NaN, NaN, (20, 25]]
Categories (2, object): [(15, 20] < (20, 25]]
可以看出分段后的结果,不在分段内的数据显示为na值,其他则显示数据所在的分段。
print(pd.cut(data,bins).labels)
结果为:
[-1 -1 0 0 1 -1 -1 1]
显示所在分段排序标签
print(pd.cut(data,bins).levels)
结果为:
Index([‘(15, 20]', ‘(20, 25]'], dtype='object')
显示所以分段标签
print(value_counts(pd.cut(data,bins)))
结果为:
显示每个分段值得个数
此外还有一个qcut的函数可以对数据进行4分位切割,用法和cut类似。
排列和采样
我们知道排序的方法有好几个,比如sort,order,rank等函数都能对数据进行排序
现在要说的这个是对数据进行随机排序(permutation)
data=np.random.permutation(5) print(data)
结果为:
[1 0 4 2 3]
这里的peemutation函数对0-4的数据进行随机排序的结果。
也可以对数据进行采样
df=pd.DataFrame(np.arange(12).reshape(4,3)) samp=np.random.permutation(3) print(df)
结果为:
print(samp)
结果为:
[1 0 2]
print(df.take(samp))
结果为:
这里使用take的结果是,按照samp的顺序从df中提取样本。
更多python 数据清洗之数据合并、转换、过滤、排序相关文章请关注PHP中文网!