pandas数据对其排序统计计算
加粗样式
前言
提示:以下是本篇文章正文内容,下面案例可供参考
一、索引对象
data:image/s3,"s3://crabby-images/b341a/b341a0ae2f5ec460d62e4eedfa291178caf14bf2" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/35d74/35d743c74d28928614e51f6778bc1d3bbf7eb360" alt="在这里插入图片描述"
在这里插入代码片
输出索引值
import numpy as np
import pandas as pd
c=np.random.randint(1,10,(5,5))
frame=pd.DataFrame(c,columns=list("abcde"))
print(frame.index)
one=frame.index
print(one)
结果为:
RangeIndex(start=0, stop=5, step=1)
RangeIndex(start=0, stop=5, step=1)
print(frame.columns)
Index(['a', 'b', 'c'], dtype='object')
二、索引重置
data:image/s3,"s3://crabby-images/3b493/3b493a570a70a12c2e13e9f0c25ea6e0a2d3c39d" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/cfd71/cfd71b5cd2d5df3a6e8d9c506fd23b1c6b292d9c" alt="在这里插入图片描述"
在这里插入代码片
import numpy as np
import pandas as pd
s=pd.Series([0,1,2,3,4],index=['a','b','c','d'])
print(s.reindex(['a','b','c','d','e'],fill_value=5))fill_value=5 填充缺少的值
data:image/s3,"s3://crabby-images/fd69d/fd69d77ad992c73832620d444648dc88604dd26c" alt="在这里插入图片描述"
在这里插入代码片
import numpy as np
import pandas as pd
print(s.reindex(['a','b','e','f'],method='ffill'))
a 0
b 1
e 3
f 4
dtype: int64
print(s.reindex(['a','b','e','f'],method='bfill'))
a 0
b 1
e 4
f 4
dtype: int64
三、Series索引操作
切片
在这里插入代码片
import numpy as np
import pandas as pd
ser_obj=pd.Series([1,2,3,4],index=['a','b','c','d'])
print(ser_obj)
print(ser_obj[0:2])
print(ser_obj['c':'b'])
结果为:
a 1
b 2
c 3
d 4
dtype: int64
a 1
b 2
dtype: int64
c 3
d 4
dtype: int64
在这里插入代码片
import numpy as np
import pandas as pd
ser_obj=pd.Series([1,2,3,4],index=['a','b','c','d'])
print(ser_obj[2])
print(ser_obj['b'])
结果为:
3
ser_obj=pd.Series([1,2,3,4],index=['a','b','c','d'])
print(ser_obj[[0,2,3]])
a 1
c 3
d 4
dtype: int64
b=[True,True,False,False]
print(ser_obj[b])
a 1
b 2
dtype: int64
print(frame['a'])
0 1
1 4
2 7
Name: a, dtype: int64
data:image/s3,"s3://crabby-images/56ff2/56ff2d36226f73cb6ac496e84eaffd714a2c6185" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/b1a41/b1a41f2ed3eec3f212a470fbb9d0cbc3772a92bf" alt="在这里插入图片描述"
在这里插入代码片
import numpy as np
import pandas as pd
frame=pd.DataFrame([[1,2,3],[4,5,6],[7,8,9]],columns=['a','b','c'])
print(frame.loc[:]['a'])
print(frame.loc[:,['a']])
结果为:
0 1
1 4
2 7
Name: a, dtype: int64
a
0 1
1 4
2 7
print(frame.iloc[0:2])
print(frame.iloc[0:2,:])
结果为:
a b c
0 1 2 3
1 4 5 6
a b c
0 1 2 3
1 4 5 6
二、算数运算与数据对齐
1.填充缺失值
在这里插入代码片
import pandas as pd
import numpy as np
obj_one=pd.Series([10,11,12],index=[0,1,2])
obj_two=pd.Series([20,21,22,23,24],index=[0,1,2,3,4])
result1=obj_one+obj_two
print(result1)
result=obj_two.add(obj_one,fill_value=0)
print(result)
结果为:
0 30.0
1 32.0
2 34.0
3 NaN
4 NaN
dtype: float64
0 30.0
1 32.0
2 34.0
3 23.0
4 24.0
dtype: float64
2.按索引排序
data:image/s3,"s3://crabby-images/6ace1/6ace15e37887dfc90551758fd3a037e2fa48cf40" alt="在这里插入图片描述"
在这里插入代码片
import numpy as np
import pandas as pd
a1=pd.Series([1,2,3,4],index=[9,3,4,1])
print(a1.sort_index())
print(a1.sort_index(ascending=False))
结果为:
1 4
3 2
4 3
9 1
dtype: int64
9 1
4 3
3 2
1 4
dtype: int64
```python
在这里插入代码片
import numpy as np
import pandas as pd
a2=pd.DataFrame([[1,2,3],[4,9,6],[7,8,9]],index=[6,4,9],columns=['a','b','c'])
print(a2.sort_values(by='b',ascending=False))
data:image/s3,"s3://crabby-images/d9c10/d9c1063f915241418c1fd8b6b07afb69172c1204" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/0ea9c/0ea9cdc3c7bb2ad935f25726e4c0363c86cb5796" alt="在这里插入图片描述"
|