python数据分析实战---Pandas

pandas的认识 :一个python的数据分析库

安装方式:pip  install pandas

pandas 是基于NumPy 的一种工具,该工具是为了解决数据分析任务而创建的。Pandas 纳入了大量库和一些标准的数据模型,提供了高效地操作大型数据集所需的工具。pandas提供了大量能使我们快速便捷地处理数据的函数和方法。你很快就会发现,它是使Python成为强大而高效的数据分析环境的重要因素之一.

  • 一个快速、高效的DataFrame对象,用于数据操作和综合索引;
  • 用于在内存数据结构和不同格式之间读写数据的工具:CSV和文本文件、Microsoft Excel、SQL数据库和快速HDF 5格式;
  • 智能数据对齐和丢失数据的综合处理:在计算中获得基于标签的自动对齐,并轻松地将凌乱的数据操作为有序的形式;
  • 数据集的灵活调整和旋转;
  • 基于智能标签的切片、花式索引和大型数据集的子集;
  • 可以从数据结构中插入和删除列,以实现大小可变;
  • 通过在强大的引擎中聚合或转换数据,允许对数据集进行拆分应用组合操作;
  • 数据集的高性能合并和连接;
  • 层次轴索引提供了在低维数据结构中处理高维数据的直观方法;
  • 时间序列-功能:日期范围生成和频率转换、移动窗口统计、移动窗口线性回归、日期转换和滞后。甚至在不丢失数据的情况下创建特定领域的时间偏移和加入时间序列;
  • 对性能进行了高度优化,用Cython或C编写了关键代码路径。
  • Python与Pandas在广泛的学术和商业领域中使用,包括金融,神经科学,经济学,统计学,广告,网络分析,等等。

pandas中文网 https://www.pypandas.cn

数据结构Series和Dataframe

一维数组Series

 Series是一维标记的数组,能够保存任何数据类型(整数,字符串,浮点数,Python对象等)。轴标签统称为索引。

ar = np.random.rand(5)
s = pd.Series(ar)
print(s)
print(s.index)   #index查看series的值
print(s.values)  #values查看series的values
---------------------------------------------------
0    0.119383
1    0.247409
2    0.248272
3    0.410680
4    0.439547
dtype: float64
RangeIndex(start=0, stop=5, step=1)
[0.11938319 0.24740862 0.24827207 0.41068032 0.43954667]

创建series的三种方法:

字典创建
dit = {'a':1,'b':2,'c':3,'f':6}
s = pd.Series(dit)
print(s)
---------------------------------
a    1
b    2
c    3
f    6
dtype: int64
数组创建
ar = np.random.rand(5)*100
s = pd.Series(ar,index=list('abcde'),dtype=np.str)
print(s)
--------------------------------------------
a    31.644744342854725
b     6.783679074968873
c     6.753556225037693
d     43.71090526035562
e     65.35205915903558
dtype: object
通过标量创建
s = pd.Series(100,index=range(10))
print(s)
-------------------------------
0    100
1    100
2    100
3    100
4    100
5    100
6    100
7    100
8    100
9    100
dtype: int64

 name属性

ar = np.random.rand(2)
s = pd.Series(ar)
s1 = pd.Series(ar,name='test')
print(s,type(s))
print(s1,type(s1))

s2 =s1.rename("abcd")
print(s2,type(s2))
print(s1,type(s1))
---------------------------
0    0.820561
1    0.330791
dtype: float64 
0    0.820561
1    0.330791
Name: test, dtype: float64 
0    0.820561
1    0.330791
Name: abcd, dtype: float64 
0    0.820561
1    0.330791
Name: test, dtype: float64 

索引

ar = np.random.rand(5)
s = pd.Series(ar)
print(s[0])   #下标索引
print(s[2])   #下标索引
s1 = pd.Series(ar,index=list('abcde'))
print(s1)
print(s1['a'])   #标签索引
print(s1[0:3],s1[4])  #切片索引

#布尔型索引
ar = np.random.rand(5)*100
s2 = pd.Series(ar)
s2[6]=None
print(s2)
bs1 = s2>50
bs2 = s2.isnull()
bs3 = s2.notnull()
print(bs1)
print(bs2)
print(bs3)

print(s2[s2>50])
print(s2[bs3])
------------------------
0.61815875542277
0.019856009429792598
a    0.618159
b    0.823132
c    0.019856
d    0.737151
e    0.840799
dtype: float64
0.61815875542277
a    0.618159
b    0.823132
c    0.019856
dtype: float64 0.8407993638916321
0    9.29894
1    84.7848
2    24.4915
3    59.9761
4    91.5569
6       None
dtype: object
0    False
1     True
2    False
3     True
4     True
6    False
dtype: bool
0    False
1    False
2    False
3    False
4    False
6     True
dtype: bool
0     True
1     True
2     True
3     True
4     True
6    False
dtype: bool
1    84.7848
3    59.9761
4    91.5569
dtype: object
0    9.29894
1    84.7848
2    24.4915
3    59.9761
4    91.5569
dtype: object

 其他属性

ar = np.random.randint(100,size=10)
s = pd.Series(ar,index=list('abcdefgjkl'))
print(s)
print(s.head())  #查看前5个
print(s.tail())  #查看后5个
s['a','e','f']=100  #修改
s.drop('b',inplace=True) #删除
s['o'] = 500   #添加
print("++++",s)


#重新索引
s1 = pd.Series(np.random.rand(5),index=list('abcde'))
s2 = s1.reindex(['b','c','d','e','f'])
print(s2)

#对齐
d = pd.Series(np.random.rand(3),index=['Tom','Marry','Jam'])
d2 = pd.Series(np.random.rand(3),index=['Tom','Lucy','Jam'])
print(d)
print(d2)
print(d2+d)
--------------------------------
a    75
b    45
c    86
d     0
e    29
f     8
g    41
j    51
k    30
l    58
dtype: int32
a    75
b    45
c    86
d     0
e    29
dtype: int32
f     8
g    41
j    51
k    30
l    58
dtype: int32
++++ a    100
c     86
d      0
e    100
f    100
g     41
j     51
k     30
l     58
o    500
dtype: int64
b    0.962842
c    0.061086
d    0.135772
e    0.845562
f         NaN
dtype: float64
Tom      0.828716
Marry    0.383809
Jam      0.600144
dtype: float64
Tom     0.048050
Lucy    0.379492
Jam     0.072854
dtype: float64
Jam      0.672999
Lucy          NaN
Marry         NaN
Tom      0.876766
dtype: float64

 

二维数组Dataframe

DataFrame是一个二维标记数据结构,具有可能不同类型的列。您可以将其视为电子表格或SQL表,或Series对象的字典。它通常是最常用的pandas对象。与Series一样,DataFrame接受许多不同类型的输入:

  • 1D ndarray,list,dicts或Series的Dict
  • 二维numpy.ndarray
  • 结构化或记录 ndarray
  • 一个 Series
  • 另一个 DataFrame

除了数据,您还可以选择传递索引(行标签)和 列(列标签)参数。如果传递索引和/或列,则可以保证生成的DataFrame的索引和/或列。因此, Series 的字典加上特定索引将丢弃与传递的索引不匹配的所有数据。

创建DataFrame的5中方式:

  由list和数组创建

#由list和数组创建
data = {
    'name':['Jack','Mary','Tom'],
    'age':[14,15,17],
    'gender':['M','W','M']
}
fr = pd.DataFrame(data)
print(fr)
print(type(fr))
print(fr.index,'数据类型是:',type(fr.index))   #行标签
print(fr.values,'数据类型是:',type(fr.values)) #值
print(fr.columns,'数据类型是:',type(fr.columns))  #列标签
-----------------------------------------------------------------
   name  age gender
0  Jack   14      M
1  Mary   15      W
2   Tom   17      M

RangeIndex(start=0, stop=3, step=1) 数据类型是: 
[['Jack' 14 'M']
 ['Mary' 15 'W']
 ['Tom' 17 'M']] 数据类型是: 
Index(['name', 'age', 'gender'], dtype='object') 数据类型是: 
由Series组成的创建
#由Series组成的创建
data1 = {'one':pd.Series(np.random.rand(2)),
         'two':pd.Series(np.random.rand(3)),
         }
print(data1)
data2 = {'one':pd.Series(np.random.rand(2),index=['a','b']),
         'two':pd.Series(np.random.rand(3),index=['a','b','c']),
         }
print(data2)

fr1 = pd.DataFrame(data1)
fr2 = pd.DataFrame(data2)
print(fr1)
print(fr2)
-----------------------------
{'one': 0    0.432652
1    0.552177
dtype: float64, 'two': 0    0.946339
1    0.326405
2    0.352883
dtype: float64}
{'one': a    0.353147
b    0.176789
dtype: float64, 'two': a    0.121450
b    0.371344
c    0.240906
dtype: float64}
        one       two
0  0.432652  0.946339
1  0.552177  0.326405
2       NaN  0.352883
        one       two
a  0.353147  0.121450
b  0.176789  0.371344
c       NaN  0.240906 
通过二维数组创建 (常用)
#通过二维数组创建 (常用)

ar = np.random.rand(9).reshape(3,3)
print(ar)
fr3 = pd.DataFrame(ar)
fr4 = pd.DataFrame(ar,index=['a','b','c'],columns=['s','h','j'])
print(fr3)
print(fr4)
------------------------
[[0.80857571 0.31437002 0.00130739]
 [0.24521627 0.04577992 0.19544072]
 [0.23923237 0.26033495 0.17534313]]
          0         1         2
0  0.808576  0.314370  0.001307
1  0.245216  0.045780  0.195441
2  0.239232  0.260335  0.175343
          s         h         j
a  0.808576  0.314370  0.001307
b  0.245216  0.045780  0.195441
c  0.239232  0.260335  0.175343 
字典组成的列表
data3 = [{'one':1,'two':2,'three':3},{'four':4,'five':5,'six':6}]
fr5 = pd.DataFrame(data3)
print(fr5)
---------------------
   one  two  three  four  five  six
0  1.0  2.0    3.0   NaN   NaN  NaN
1  NaN  NaN    NaN   4.0   5.0  6.0
字典组成的字典
data4 = {
    'Tom':{'art':67,'english':98,'china':76},
    'Mary':{'art':45,'english':78,'china':70},
    'Lucy':{'art':58,'english':79},
        }
fr6 = pd.DataFrame(data4)
print(fr6)
---------------------------
        Tom  Mary  Lucy
art       67    45  58.0
english   98    78  79.0
china     76    70   NaN

 索引

import  numpy as np
import pandas as pd


df = pd.DataFrame(np.random.rand(12).reshape(3,4)*100,
                  index=['one','two','three'],columns=['a','b','c','d']
                  )
df2 = pd.DataFrame(np.random.rand(12).reshape(3,4)*100,
                  columns=['a','b','c','d']
                  )

print(df)
print(df2)

data = df['a']
data1 = df[['a','b']]
print('data',data)
print('data1',data1)     #选择列

data3 = df.loc['one']    #按index选择行
data4 = df.loc[['three','one']]
print('data3',data3)
print('data4',data4)   #选择行

data5 = df.iloc[-1]  #按整数位置选择行
print('data5',data5)

print("单标签索引/n")
print(df.loc['one'])
print(df2.loc[1])

print("多标签索引/n")
print(df.loc[['two','one']])
print(df2.loc[[2,1]])
#
print("切片索引/n")
print(df.loc['one':'two'])
print(df2.loc[1:2])
---------------------------
               a          b          c          d
one    79.285201  73.277718  12.225063  18.830074
two     2.400540  49.604940  80.337070  47.133134
three  17.399693  92.839253  90.041425  75.505320
           a          b          c          d
0  47.065633  21.284022  30.118641  85.652279
1  12.201863  48.841603  23.367143  32.276774
2  77.422617  55.812583  56.130735  64.983035
data one      79.285201
two       2.400540
three    17.399693
Name: a, dtype: float64
data1                a          b
one    79.285201  73.277718
two     2.400540  49.604940
three  17.399693  92.839253
data3 a    79.285201
b    73.277718
c    12.225063
d    18.830074
Name: one, dtype: float64
data4                a          b          c          d
three  17.399693  92.839253  90.041425  75.505320
one    79.285201  73.277718  12.225063  18.830074
data5 a    17.399693
b    92.839253
c    90.041425
d    75.505320
Name: three, dtype: float64
单标签索引/n
a    79.285201
b    73.277718
c    12.225063
d    18.830074
Name: one, dtype: float64
a    12.201863
b    48.841603
c    23.367143
d    32.276774
Name: 1, dtype: float64
多标签索引/n
             a          b          c          d
two   2.400540  49.604940  80.337070  47.133134
one  79.285201  73.277718  12.225063  18.830074
           a          b          c          d
2  77.422617  55.812583  56.130735  64.983035
1  12.201863  48.841603  23.367143  32.276774
切片索引/n
             a          b          c          d
one  79.285201  73.277718  12.225063  18.830074
two   2.400540  49.604940  80.337070  47.133134
           a          b          c          d
1  12.201863  48.841603  23.367143  32.276774
2  77.422617  55.812583  56.130735  64.983035

布尔值索引

df = pd.DataFrame(np.random.rand(12).reshape(3,4)*100,
                  index=['one','two','three'],columns=['a','b','c','d']
                  )
b1 = df<20
print(b1,type(b1))
print(df[b1])   #不做索引对每一个值进行判断

b2 = df["a"]<20
print(b2,type(b2))
print(df[b2])   #单行判断

b3 = df[["a",'b']]<20
print(b3,type(b3))
print(df[b3])   #多行判断

b4 = df.loc[["one",'two']]<50
print(b4,type(b4))
print(df[b4])   #多行判断

-------------------------------------
           a      b      c      d
one     True   True  False  False
two    False  False  False  False
three   True  False  False  False 
               a          b   c   d
one    12.319044  16.517952 NaN NaN
two          NaN        NaN NaN NaN
three   8.939486        NaN NaN NaN
one       True
two      False
three     True
Name: a, dtype: bool 
               a          b          c          d
one    12.319044  16.517952  97.270662  76.200591
three   8.939486  38.428862  25.783585  30.355222
           a      b
one     True   True
two    False  False
three   True  False 
               a          b   c   d
one    12.319044  16.517952 NaN NaN
two          NaN        NaN NaN NaN
three   8.939486        NaN NaN NaN

  多重索引

df = pd.DataFrame(np.random.rand(12).reshape(3,4)*100,
                  index=['one','two','three'],columns=['a','b','c','d']
                  )

print(df['a'].loc['one'])
print(df['a'].loc[['one','two']])
print(df[['b','c','d']].iloc[1:2])
print(df[df<50][['a','b']])
--------------------------------
31.995689334678335
one    31.995689
two     6.516284
Name: a, dtype: float64
             b          c          d
two  19.048351  31.111981  60.956516
               a          b
one    31.995689  38.992923
two     6.516284  19.048351
three        NaN  31.623816

 其他属性

import  numpy as np
import pandas as pd


df = pd.DataFrame(np.random.rand(10).reshape(5,2),
                  columns=['a','b']
                  )

print(df)
print(df.T)   #转置
print(df.head(2))  #前2列
print(df.tail(2))  #后2列

df2 = pd.DataFrame(np.random.rand(16).reshape(4,4),
                  columns=['a','b','c','d']
                  )
print(df2)
df2['c']=100  #修改
df2['e']=10   #添加
print(df2)


print(df.drop(0,inplace=True))  #删除行,inplace  删除后生成新数据,不改变原数据
print(df.drop(['a'],axis=1))  #删除列,axis=1  删除后生成新数据,不改变原数据


#对齐


#排序
print(df.sort_values(['a'],ascending=True))  #升序
print(df.sort_values(['a'],ascending=True))  #降序

-----------------------------------------------------------------
          a         b
0  0.940085  0.181402
1  0.536894  0.488670
2  0.217216  0.854319
3  0.478155  0.066919
4  0.467400  0.194862
          0         1         2         3         4
a  0.940085  0.536894  0.217216  0.478155  0.467400
b  0.181402  0.488670  0.854319  0.066919  0.194862
          a         b
0  0.940085  0.181402
1  0.536894  0.488670
          a         b
3  0.478155  0.066919
4  0.467400  0.194862
          a         b         c         d
0  0.849237  0.284547  0.353720  0.470520
1  0.294418  0.909727  0.375445  0.975046
2  0.588561  0.386173  0.703177  0.341634
3  0.180870  0.831200  0.392450  0.036837
          a         b    c         d   e
0  0.849237  0.284547  100  0.470520  10
1  0.294418  0.909727  100  0.975046  10
2  0.588561  0.386173  100  0.341634  10
3  0.180870  0.831200  100  0.036837  10
None
          b
1  0.488670
2  0.854319
3  0.066919
4  0.194862
          a         b
2  0.217216  0.854319
4  0.467400  0.194862
3  0.478155  0.066919
1  0.536894  0.488670
          a         b
2  0.217216  0.854319
4  0.467400  0.194862
3  0.478155  0.066919
1  0.536894  0.488670

时间模块

datetime.datetime()

t1 = datetime.datetime.now()
t2 = datetime.datetime(2016,2,5)
t3 = datetime.datetime(2016,2,5,12,30,34)
print(t1,type(t1))
print(t2,type(t2))
print(t3,type(t3))
---------------------------
2019-09-17 12:25:54.780962 
2016-02-05 00:00:00 
2016-02-05 12:30:34 

  datetime.delta()

t1 = datetime.datetime(2016,4,6)
t2 = datetime.timedelta(10,200)  #默认(天,秒)
print(t1+t2)
---------------------------
2016-04-16 00:03:20  
时间格式的转化
from dateutil.parser import parse

date = "2015 2 20"
date1 = "2015-3-25"
date2 = "2016/3/8"
print(parse(date))
print(parse(date1))
print(parse(date2))

----------------------------
2015-02-20 00:00:00
2015-03-25 00:00:00
2016-03-08 00:00:00

  pd.timeStamp()时间戳

date1 = "2017-05-01 12:25:12"
date2 = datetime.datetime(2017,5,6,14,15,23)
t1 = pd.Timestamp(date1)  #时间戳
t2 = pd.Timestamp(date2)
print(t1,type(t1))
print(t2,type(t2))
print(date2,type(date2))
---------------------------------
2017-05-01 12:25:12 
2017-05-06 14:15:23 
2017-05-06 14:15:23 

  pd.to_datetime()

date1 = "2017-05-01 12:25:12"
date2 = datetime.datetime(2017,5,6,14,15,23)

t1 = pd.to_datetime(date1)  #时间戳
t2 = pd.to_datetime(date2)
print(t1,type(t1))
print(t2,type(t2))


#多个时间数据,会转化成pandas的Datetime的Index
ls_date = ['2017-01-01','2017-01-02','2017-01-03']
t3 = pd.to_datetime(ls_date)
print(t3,type(t3))

#当一组数据中夹杂着其他的数组
date3 = ['2017-01-01','2017-01-02','2017-01-03','hello','2018-01-05']
t4 = pd.to_datetime(date3,errors='ignore')  #返回原始数据,这里直接是生成一组数据
print(t4,type(t4))

t5 = pd.to_datetime(date3,errors='coerce')  #缺失值返回Nat,结果是DatetimeIndex
print(t5,type(t5))

------------------------------------------------
2017-05-01 12:25:12 
2017-05-06 14:15:23 
DatetimeIndex(['2017-01-01', '2017-01-02', '2017-01-03'], dtype='datetime64[ns]', freq=None) 
Index(['2017-01-01', '2017-01-02', '2017-01-03', 'hello', '2018-01-05'], dtype='object') 
DatetimeIndex(['2017-01-01', '2017-01-02', '2017-01-03', 'NaT', '2018-01-05'], dtype='datetime64[ns]', freq=None) 
date_range(start,end,periods,freq)
'''
date_range(start,end,periods,freq)
    start:开始时间
    end:结束时间
    periods:偏移量
    freq:频率  默认,天  pd.date_range()默认频率为日历日  pd.bdate_range()默认频率为工作日
'''
date = pd.date_range('2014-01-01','2014-02-01')
date1 = pd.date_range(start='2014-01-01',periods=10)
date2 = pd.date_range(end='2014-01-01',periods=10)
date3 = pd.date_range('2014-01-01','2014-01-02',freq="H")
print(date)
print(date1)
print(date2)
print(date3)

#normalize 时间参数值正则化到午夜时间戳
date4 = pd.date_range('2019-05-01 12:25:00',periods=2,name='hello',normalize=True)
print(date4)

print(pd.date_range('20190101','20190105'))   #默认左右闭合
print(pd.date_range('20190101','20190105',closed='right')) #右开左闭
print(pd.date_range('20190101','20190105',closed='left'))  #左开右闭
print(pd.bdate_range('20190101','20190107'))  #默认频率是工作日

#日期范围频率
print(pd.date_range('20190101','20190110'))  #默认是天
print(pd.date_range('20190101','20190110',freq='B')) #每工作日
print(pd.date_range('20190101','20190110',freq='H'))  #每小时
print(pd.date_range('20190101 12:00','20190110 12:20',freq='T'))  #每分钟
# print(pd.date_range('20190101 12:00:00','20190110 12:20:01',freq='S'))  #每秒
# print(pd.date_range('20190101 12:00:00','20190110 12:20:01',freq='L'))  #每毫秒(千分之一秒)
# print(pd.date_range('20190101 12:00:00','20190110 12:20:01',freq='U'))  #每微秒(百万分之一秒)


#星期的缩写:MON-TUE-WED-THU-FRI-SAT-SUN
print(pd.date_range('20190101','20190210',freq='W-MON'))  #从指定星期几开始算起,每周一
print(pd.date_range('20190101','20190210',freq='WOM-2MON'))  #每月的第几个星期几开始算,这里是每月第二个星期一

#月份缩写:JAN/FEB/MAR/APR/MAY/JUE/JUL/AUG/SEP/OCT/NOV/DEC
print(pd.date_range('2018','2020',freq='M'))#每月最后一个日历日
print(pd.date_range('2018','2020',freq='Q-DEC'))#Q月,指定月为季度末,每个季度末的最后一个月的最后一个日历日
print(pd.date_range('2018','2020',freq='A-DEC'))#A月,每年指定月份的最后一个日历日

print(pd.date_range('2018','2020',freq='BM'))#每月最后一个工作日
print(pd.date_range('2018','2020',freq='BQ-DEC'))#Q月,指定月为季度末,每个季度末的最后一个月的最后一个工作日
print(pd.date_range('2018','2020',freq='BA-DEC'))#A月,每年指定月份的最后一个工作日

print(pd.date_range('2018','2020',freq='MS'))#每月第一个日历日
print(pd.date_range('2018','2020',freq='QS-DEC'))#Q月,指定月为季度末,每个季度末的最后一个月的第一个日历日
print(pd.date_range('2018','2020',freq='AS-DEC'))#A月,每年指定月份的第一个日历日

print(pd.date_range('2018','2020',freq='BMS'))#每月第一个工作日
print(pd.date_range('2018','2020',freq='BQS-DEC'))#Q月,指定月为季度末,每个季度末的最后一个月的第一个工作日
print(pd.date_range('2018','2020',freq='BAS-DEC'))#A月,每年指定月份的第一个工作日


#复合频率
print(pd.date_range('20180701','20180801',freq='7D'))#7天
print(pd.date_range('20180701','20180801',freq='2H30min'))#2小时30分钟
print(pd.date_range('2018','2019',freq='2MS'))#2月,每月最后一个日历日

  asfreq()  时间频率转化

date = pd.Series(
    np.random.rand(4),
    index=pd.date_range('20180101','20180104')
)
print(date)
print(date.asfreq('4H'))  #值是NAN
print(date.asfreq('4H',method='ffill'))  #用前面值填充
print(date.asfreq('4H',method='bfill'))  #用后面的值填充

  shift()超前、滞后数据

date = pd.Series(
    np.random.rand(4),
    index=pd.date_range('20180101','20180104')
)
print(date)
print(date.shift(2))  #前移2位
print(date.shift(-2))  #后移2位

  period()时期

#创建时期
date = pd.Period('2017',freq='M')
print(date)

date2 = pd.period_range('2017','2018',freq='M')
print(date2,type(date2))

#时间戳与日期之间的转化
t = pd.date_range('20180101',periods=10,freq='M')
t2 = pd.period_range('2018','2019',freq='M')

ts = pd.Series(np.random.rand(len(t)),index=t)
print(ts)
print(ts.to_period())  #时间戳转日期

ts2 = pd.Series(np.random.rand(len(t2)),index=t2)
print(ts2)
print(ts2.to_timestamp())  #日期转时间戳

  索引与切片

date = pd.DataFrame(
    np.random.rand(30).reshape(10,3)*100,
    index = pd.date_range('20170101','20170106',freq='12H',closed='left'),
    columns=['value1','value2','value3']
)
print(date)
print(date[:4])  #前4行
print(date["20170104"].iloc[1])   #取20170104 12:00:00的值
print(date.loc["20170104":'20170105'])  #切片

  resample()重采样

date = pd.Series(
    np.arange(1,13),
    index=pd.date_range('20170101',periods=12)
)
print(date)
#
ts = date.resample("5D")
ts2 = date.resample("5D").sum()  #求和
print(ts,type(ts))
print(ts2,type(ts2))

print(date.resample("5D").mean() ) #求平均数
print(date.resample("5D").max() ) #求最大
print(date.resample("5D").min() ) #求最小
print(date.resample("5D").median() ) #求中值
print(date.resample("5D").first() ) #求第一个
print(date.resample("5D").last() ) #求最后一个
print(date.resample("5D").ohlc() ) #金融中的OHLC样本


#降采样
print(date.resample("5D",closed='left').sum() )
print(date.resample("5D",closed='right').sum() )

print(date.resample("5D",label='left').sum() )
print(date.resample("5D",label='right').sum() )


#升采样及插值
date2 = pd.DataFrame(
    np.arange(15).reshape(5,3),
    index=pd.date_range('20170101',periods=5),
    columns=['a','b','c']
)
print(date2)
print(date2.resample("12H").asfreq())
print(date2.resample("12H").ffill())
print(date2.resample("12H").bfill())

通用方法

数值计算和统计基础

 

import  numpy as np
import pandas as pd


df1 = pd.DataFrame(
    {'key1':[4,5,6,np.nan,7],
     'key2':[1,2,np.nan,9,7],
     'key3':[2,4,5,'j','k']
     })

print(df1)
print(df1.sum())
print(df1.sum(axis=1))  #axis=1 按行计算  默认是0
print(df1.sum(skipna=True))  #skipna  是否忽略NaN,默认是True,由NaN的值计算结果还是NaN


df = pd.DataFrame(
    {'key1':np.arange(1,11),
     'key2':np.random.rand(10)*100}
)
print(df)
print(df.mean(),'求均值')
print(df.count(),'统计每列非NaN的数量')
print(df.min(),'最小值')
print(df.max(),'最大值')
print(df.quantile(q=0.5),'统计分数位,参数q确定位置')
print(df.median(),'算数中位数')
print(df.std(),'方差')
print(df.skew(),'样本的偏度')
print(df.kurt(),'样本的峰度')

df['key1_s']=df['key1'].cumsum()
df['key2_s']=df['key2'].cumsum()   #样本的累计和
print(df)

df['key2_p']=df['key2'].cumprod()
df['key1_p']=df['key1'].cumprod()  #样本的累计积
print(df)


s = pd.Series(list('aabcdfgfgtf'))
print(s)
print(s.unique()) #唯一值
print(s.value_counts(sort=True)) #计算样本出现的频率

print(s.isin(['a','o']))   #是否在该series成员里面
print(df.isin([1,4]))   #是否在该Dateframe成员里面
   

文本数据

s = pd.Series(['A','c','D','bbhello','b',np.nan])
df = pd.DataFrame({'key1':list('abcde'),'key2':['abc','AS',np.nan,4,'fa']})
print(df)
print(s)

print(s.str.count('b'))#统计每行的'b'
print(s.str.upper()) #大写
print(s.str.lower())#小写
print(s.str.len())#长度
print(s.str.startswish('a'))#判断起始值
print(s.str.endswish('a'))#判断结束值
print(s.str.strip())#去空格
print(s.str.replace())#代替
print(s.str.split(','))#分裂
print(s.str[0])#字符索引

合并

合并
pd.merge(
    left,
    right,
    how="inner"交集, how='outer'并集
    on=None,
    left_on=None,
    right_on=None,
    left_index=False,
    right_index=False,
    sort=False,
    suffixes=("_x", "_y"),
    copy=True,
    indicator=False,
    validate=None,
)

连接、修补

'''
pd.concat(
    objs,
    axis=0,  行+行  axis=1 列+列
    join="outer",  #并集   inner交集
    join_axes=None,  #指定联合index
    ignore_index=False,
    keys=None,   序列,默认无,
    levels=None,
    names=None,
    verify_integrity=False,
    sort=None,
    copy=True,)
      
'''
df1 =pd.DataFrame([[np.nan,3,5],[-4,6,np.nan],[np.nan,4,np.nan]])
df2 =pd.DataFrame([[-2,np.nan,5],[5,8,19]],index=[1,2])
print(df1)
print(df2)
print(df1.combine_first(df2))  #df1的空值被df2值代替
df1.update(df2)  #df2直接覆盖df1 相同的index的位置
print(df1) 
# df1 = pd.DataFrame(np.random.rand(8).reshape(4,2),index=['a','b','c','d'],columns=['values1','values2'])
# df2 = pd.DataFrame(np.random.rand(8).reshape(4,2),index=['e','f','g','h'],columns=['values1','values2'])
# print(df1)
# print(df2)
# print(pd.concat([df1,df2]))

df1 = pd.DataFrame(np.random.rand(8).reshape(4,2),index=['a','b','c','d'],columns=['values1','values2'])
df2 = pd.DataFrame(np.arange(8).reshape(4,2),index=['a','b','c','d'],columns=['values1','values2'])
df1['values1']['a','b']=np.nan
print(df1)
print(df2)
print(df1.combine_first(df2))

去重、替换

#去重
s=pd.Series([1,1,2,2,2,3,3,3,4,5,5,56])
print(s)
print(s.duplicated())
print(s[s.duplicated() == False])

s_r = s.drop_duplicates()
print(s_r)

#替换
df=pd.Series(list('abcdeaade'))
print(df)
print(df.replace('a',1))
print(df.replace(['a','b'],1))
print(df.replace({'a':123,'d':234}))

数据分组

 

df = pd.DataFrame({
    'A':['foo','bar','foo','bar','foo','bar'],
    'B':['one','two','three','one','two','one'],
    'C':np.arange(1,7),
    'D':np.arange(8,14)
})
print(df)
a = df.groupby('A').mean()
b = df.groupby(['A','B']).mean()
c = df.groupby('A')['D'].mean() #以A分组,算D的均值
print(a,type(a))
print(b,type(b))
print(c,type(c))

#分组---可迭代的对象
df1 = pd.DataFrame({'X':['A','B','A','B'],'Y':[1,2,3,4]})
print(df1)
print(list(df1.groupby('X')))  #列表
print(list(df1.groupby('X'))[0])  #元组
for n,g in df1.groupby('X'):
    print(n)
    print(g)
print('++++++++++++')
print(df1.groupby('X').get_group('A'))  #提取分组后的组

#其他轴上分组
df = pd.DataFrame({
    'key1':['a','b'],
    'key2':['one','two'],
    'C':np.arange(1,3),
    'D':np.arange(8,10)
})
print(df)
print(df.dtypes)
for n,g in df.groupby(df.dtypes,axis=1):
    print(n)
    print(g)


#通过字典或者Series分组
df = pd.DataFrame(np.arange(16).reshape(4,4),columns=['a','b','c','d'])
date = {'a':'one','b':'two','c':'one','d':'two','e':'three'}
by= df.groupby(date,axis=1)
print(by.sum())

s = pd.Series(date)
s_b = s.groupby(s).count()
print(s_b)


#通过函数分组
df = pd.DataFrame(np.arange(16).reshape(4,4),columns=['a','b','c','d'],index=['abc','bcd','bb','a'])
s = df.groupby(len).sum()
print(s)

#多函数计算 agg()
df = pd.DataFrame({
    'A':[1,2,1,2],
    'B':np.arange(8,12),
    'C':np.arange(1,5),
    'D':np.arange(8,12)
})
print(df)
print(df.groupby('A').agg(['mean',np.sum]))
print(df.groupby('A')['B'].agg({'result1':np.mean,'result2':np.sum}))

 

文件读取

 

 pd.read_table(
            obj,   文件路径
            delimiter=',', 用于拆分字符,
            header=0,   用作列名序号,默认为0
            index_col=1 指定某列为行索引,否则自动索引0,1...
        )
pd.read_csv(
            obj,
            engine='python', 使用的分析引擎 可以选择python或者C
            encoding='utf8',  指定字符集类型,编码类型
        ) 
pd.read_excel(
            obj,
            sheetname=None, 返回多表使用sheetname=[0,1],默认返回全部
            header=0,   用作列名序号,默认为0
            index_col=1 指定某列为列索引,否则自动索引0,1...
            
        )

  

转载于:https://www.cnblogs.com/garrett0220/p/11497371.html

你可能感兴趣的:(python数据分析实战---Pandas)