Pandas学习笔记 01 python和NumPy基础
pandas预备知识:python和numpy基础
1 python基础
1.1 列表推导式与条件赋值
列表推导式:[* for i in],支持多层嵌套
条件赋值:value = a if condition else b
1.2 匿名函数与map方法
匿名函数: lambda
map方法:需要list()转换为列表
1.3 zip对象与enumerate方法
zip函数将多个可迭代对象打包成一个元组构成的可迭代对象,通过tuple和list可以获得相应结果。
enumerate在迭代时绑定迭代元素的遍历序号。
*zip可进行解压。
2 numpy基础
2.1 np数组的构造
- 
一般方法: np.array([])
- 
等差序列 
	np.linspace(start, stop, num=50, endpoint=True, retstep=False, dtype=None, axis=0),一般设置起点、终点(包含)和样本个数。
		np.arange([start,] stop[, step,], dtype=None, *, like=None),一般设置起点、终点(不包含)和步长。
- 特殊矩阵
	zeros:全零矩阵
	eye:单位矩阵,可设置偏移主对角线量
	full:指定值填充矩阵
- 随机矩阵 np.random
	rand:0-1均匀分布的随机数组
	randn: 标准正态分布的随机数组
	randint: 随机整数组
	choice:随机列表抽样
	permutation:打散原列表
2.2 np数组的变形与合并
转置:.T
上下合并:r_
左右合并:c_
维度变换:reshape,order='C/F'表示逐行/列读取,维度空缺使用-1
2.3 np数组的切片与索引
支持使用slice类型的start:end:step切片,也可直接传入列表指定某个维度的索引进行切片。
可以利用np.ix_在对应维度上使用布尔索引,此时不能使用slice切片。
一维数组可直接进行布尔索引,无需np.ix_。
2.4 常用函数
- where条件函数
 指定满足条件与不满足条件位置对应的填充值
- nonzero,argmax,argmin
	nonzero返回非零数的索引,argmax, argmin分别返回最大和最小数的索引
- 
any, allany:序列至少存在一个True或非零元素时返回True,否则返回Falseall:序列元素全为True或非零元素时返回True,否则返回False
- 
cumprod,cumsum,diffcumprod,cumsum分别表示累乘和累加函数,返回同长度数组。diff表示与前一元素做差,返回长度比原数组少1。
- 
统计函数 
	常用统计函数:max, min, mean, median, std, var, sum, quantile
	通过array.max()调用,其中quantile为全局方法,通过np.quantile调用。
	略过缺失值可使用相应的nan*方法,如nanmax。
	协方差和相关系数:np.cov(s1, s2),np.corrcoef(s1, s2)
2.5 广播机制
- 
标量与数组 概念上将标量拉伸到数组大小,再逐个运算 实际上直接使用原标量运算,内存和计算效率更高 
- 
数组与数组 
 操作两个数组时,NumPy按位比较维度形状。
 两个维度兼容的情况:维度相同或其中一个维度为1
2.6 向量与矩阵的计算
向量内积:dot
向量范数和矩阵范数:np.linalg.norm
矩阵乘法:@
参考:
joyful pandas教程 https://github.com/datawhalechina/joyful-pandas
NumPy官方文档 https://numpy.org/doc/stable/user/basics.broadcasting.html
 
                    
                     
                    
                 
                    
                
 
                
            
         
         浙公网安备 33010602011771号
浙公网安备 33010602011771号