目录
Pandas介绍
相比 Numpy 和 matplotlib ,pandas:
- 增强图表可读性
比如在 numpy 中创建成绩表样式:
如果数据展示为这样,可读性就更友好: -
便捷的数据处理能力
- 读取文件方便
- 封装了Matplotlib、Numpy的画图和计算
Pandas数据结构
1. Series
Series的创建
# 导入pandas
import pandas as pd
pd.Series(data=None, index=None, dtype=None)
参数:
data | 传入的数据,可以是ndarray、list等 |
index | 索引,必须是唯一的,且与数据的长度相等。如果没有传入索引参数,则默认会自动创建一个从0-N的整数索引。 |
dtype | 数据的类型 |
- 通过已有数据创建:
# 导入pandas
import pandas as pd
data = range(10)
s = pd.Series(data)
print(s)
- 指定索引:
# 导入pandas
import pandas as pd
data = range(5)
s = pd.Series(data=data, index=['a', 'b', 'c', 'd', 'e'])
print(s)
- 通过字典数据创建
# 导入pandas
import pandas as pd
a = {'red': 100, 'blue': 200, 'green': 500, 'yellow': 1000}
s = pd.Series(a)
print(s)
Series的属性
- index
# 导入pandas import pandas as pd a = {'red': 100, 'blue': 200, 'green': 500, 'yellow': 1000} s = pd.Series(a) print(s.index)
- values
# 导入pandas import pandas as pd a = {'red': 100, 'blue': 200, 'green': 500, 'yellow': 1000} s = pd.Series(a) print(s.values)
2. DataFrame
DataFrame的创建
# 导入pandas
import pandas as pd
pd.DataFrame(data=None, index=None, columns=None)
参数:
index | 行标签。如果没有传参数,默认自动创建 0-N 的整数索引。 |
columns | 列标签。如果没有传参数,默认自动创建 0-N 的整数索引。 |
-
通过已有数据创建
# 导入pandas from random import random import numpy as np import pandas as pd # 随机生成 60到100,10行5列 的数据 score = np.random.randint(60, 100, (10, 5)) s = pd.DataFrame(score) print(s)
- 增加行、列索引
# 导入pandas from random import random import numpy as np import pandas as pd # 随机生成 60到100,10行5列 的数据 score = np.random.randint(60, 100, (10, 5)) # 构造行索引序列 subjects = ["语文", "数学", "英语", "政治", "体育"] # 构造列索引序列 stu = ['同学' + str(i) for i in range(score.shape[0])] # 添加行索引 data = pd.DataFrame(score, columns=subjects, index=stu) print(data)
DataFrame的属性
- shape:行数和列数
import numpy as np import pandas as pd # 随机生成 60到100,10行5列 的数据 score = np.random.randint(60, 100, (10, 5)) data = pd.DataFrame(score) print(data.shape)
- index:DataFrame的行索引列表
- columns:DataFrame的列索引列表
- values:直接获取其中array的值
- T:转置
- head(n):前n行内容,不传参数默认5
- tail(n):后n行内容,不传参数默认5
DatatFrame索引的设置
- 修改行列索引值
stu = ["学生_" + str(i) for i in range(score_df.shape[0])] # 必须整体全部修改 data.index = stu
注意:必须整体全部修改!以下修改方式是错误的:
# 错误修改方式 data.index[3] = '学生_3'
-
重设索引:设置新的下标索引
# 重置索引,drop=False data.reset_index() data.reset_index(drop=True)
drop:默认为False,不删除原来索引,如果为True,删除原来的索引值
-
把某列值设置为新的索引
set_index(keys, drop=True)
keys:列索引名或者列索引名称的列表
drop:boolean, 默认True:当做新的索引,删除原来的列也可以设置多个索引:
df = df.set_index(['year', 'month'])
3. MultiIndex
multiIndex的特性
index:
multiIndex 的创建
import pandas as pd
arrays = [
[1, 1, 2, 2],
['red', 'blue', 'red', 'blue']
]
pd.MultiIndex.from_arrays(arrays, names=('number', 'color'))
4. Panel
panel的创建:
pandas.Panel(data=None, items=None, major_axis=None, minor_axis=None)
import numpy as np
import pandas as pd
p = pd.Panel(
data=np.arange(24).reshape(4, 3, 2),
items=list('ABCD'),
major_axis=pd.date_range('20130101', periods=3),
minor_axis=['first', 'second']
)
示例讲解:存储3维数组的Panel结构
-
data:ndarray或者dataframe
-
items:索引或类似数组的对象,axis=0
-
major_axis : 索引或类似数组的对象,axis=1
-
minor_axis : 索引或类似数组的对象,axis=2