一、通用函数:快速的元素级数组函数
通用函数(即ufunc)是一种对ndarray中的数据执行元素级运算的函数。你可以将其看作是简单的函数(接受一个或多个标量值,并产生一个或多个标量值)的矢量化包装器。
1、一元ufunc
data:image/s3,"s3://crabby-images/2b648/2b64822c6153dcfed6107c13f37a61e605de590d" alt=""
data:image/s3,"s3://crabby-images/c8410/c84100493b6f01ec06b7a93b6da6111d212e234f" alt=""
eg:
data:image/s3,"s3://crabby-images/c967e/c967ec8cdbe42e7a009997d1fe6a20b1c5ece76d" alt=""
data:image/s3,"s3://crabby-images/9448a/9448a7011fd648abcafe4348ab95a607514cc563" alt=""
data:image/s3,"s3://crabby-images/969dc/969dc2c40b6fb0c55b5314e30077c15c43c6d7c6" alt=""
2、二元ufunc
data:image/s3,"s3://crabby-images/6cea0/6cea07a26d2f1986c6df20181be424d9ab6f9ef4" alt=""
eg:
data:image/s3,"s3://crabby-images/90025/900253a89ecfc31a8035efe2d711c0c63d1b2cf9" alt=""
二、利用数组进行数据处理
numpy数组使你可以将许多种数据处理任务表述为简洁的数组表达(否则需要编写循环)。
用数组表达式代替循环的做法,通常被称为矢量化。
eg: 假设我们想要在一组值上计算函数sqrt(x^2 + y^2)。np.meshgrid函数接受两个一维数组,并产生两个二维矩阵(对应两个数组中所有的(x,y)对)
data:image/s3,"s3://crabby-images/437d4/437d4a64bb8f574931519deb0586f26575015ba6" alt=""
data:image/s3,"s3://crabby-images/86a65/86a65595d78562649bfb5ca0655d565b005c702e" alt=""
data:image/s3,"s3://crabby-images/709b3/709b320a930543db9d16242121d59e945235aa92" alt=""
1、将条件逻辑表述为数组运算
numpy.where函数是三元表达式 x if condition else y 的矢量化版本。假设我们有一个布尔数组和两个值数组:
data:image/s3,"s3://crabby-images/58649/58649c1bf33e7b04f5fa82156064cb2a74e23f31" alt=""
data:image/s3,"s3://crabby-images/5df53/5df53afbb6c2cc736420619e3d69bad0a0a21036" alt=""
2、数学和统计方法
可以通过数组上的一组数学函数对整个数组或某个轴向的数据进行统计。sum,mean以及标准差std等聚合计算既可以当做数组实例方法调用,也可以当做顶级NumPy函数使用。
data:image/s3,"s3://crabby-images/be81c/be81c4d0c3ee5fba605898a42f46dfc94fa7f60b" alt=""
data:image/s3,"s3://crabby-images/879be/879bed14a81535246679388376c8844b56e10bfe" alt=""
data:image/s3,"s3://crabby-images/65cdb/65cdbc63a6d3edbae57668e4de504f20687d4ae4" alt=""
data:image/s3,"s3://crabby-images/c5cc2/c5cc2ff4c0c96d4f0f99c9352a1e44bc0236ae29" alt=""
data:image/s3,"s3://crabby-images/24ba0/24ba00ab48e2a0637d6ef29f24a63b4cb11feee6" alt=""
data:image/s3,"s3://crabby-images/2e37d/2e37dde3494136f10734200e2ef310c668c2a565" alt=""
data:image/s3,"s3://crabby-images/4f084/4f084dc01dd126960a35e48858376fabd04a9ec8" alt=""
3、用于布尔数组的方法
data:image/s3,"s3://crabby-images/769d3/769d3eb6db804abc9ac7e6eaa184610819857aff" alt=""
4、排序
sort()函数
data:image/s3,"s3://crabby-images/0b7ac/0b7acad96a4e2da9c45095c5d69ae8bdf7df136d" alt=""
5、唯一化及其他的集合逻辑
unique()
与其等价的python纯代码:
sorted(set(name))
data:image/s3,"s3://crabby-images/a48b9/a48b91857a24aa81da23e54592af12a5ad68ee09" alt=""
data:image/s3,"s3://crabby-images/e6565/e65652e25e69df613ec11792dc6dadb6d6390697" alt=""
data:image/s3,"s3://crabby-images/b2f23/b2f23547698890c81d931c9a8aa68d6205a20826" alt=""
data:image/s3,"s3://crabby-images/802e2/802e23c6174ec829efcc728b39b485027afc8cc3" alt=""
eg:
data:image/s3,"s3://crabby-images/e99e4/e99e4f2ca538287a6611e26b3c9ed07fad785a52" alt=""
网友评论