今天学习了:

13, NumPy字符串处理函数
14, NumPy数学函数
15, NumPy算术运算
numpy_test7.py : 
import numpy as np

'''
13, NumPy字符串处理函数 NumPy处理字符串数组函数 函数名称 描述
add() 对两个数组相应位置的字符串做连接操作。
multiply() 返回多个字符串副本,比如将字符串“ hello”乘以3,则返回字符串“ hello hello hello”。
center() 用于居中字符串,并将指定的字符,填充在原字符串的左右两侧。
capitalize() 将字符串第一个字母转换为大写。
title() 标题样式,将每个字符串的第一个字母转换为大写形式。
lower() 将数组中所有的字符串的大写转换为小写。
upper() 将数组中所有的字符串的小写转换为大写。
split() 通过指定分隔符对字符串进行分割,并返回一个数组序列,默认分隔符为空格。
splitlines() 以换行符作为分隔符来分割字符串,并返回数组序列。
strip() 删除字符串开头和结尾处的空字符。
join() 返回一个新的字符串,该字符串是以指定分隔符来连接数组中的所有元素。
replace() 用新的字符串替换原数组中指定的字符串。
decode() 用指定的编码格式对数组中元素依次执行解码操作。
encode() 用指定的编码格式对数组中元素依次执行编码操作。 上述函数基于 Python 内置的字符串函数实现, 下面对一些常用函数进行讲解。
''' '''
1) numpy.char.add()
numpy.char.add() 将两个数组对应位置的字符串元素进行连接。
'''
print("----1) numpy.char.add()----")
arr1 = ['Hello ', 'Welcome ']
arr2 = ['World', 'PandaCode']
print('np.char.add(arr1, arr2) : ', np.char.add(arr1, arr2))
'''
np.char.add(arr1, arr2) : ['Hello World' 'Welcome PandaCode']
''' '''
2) numpy.char.multiply()
该函数将指定的字符串进行多次拷贝,并将拷贝结果返回。
'''
print("----2) numpy.char.multiply()----")
str1 = ' PandaCode '
print('str1 : ', str1)
str2 = np.char.multiply(str1, 3)
print('np.char.multiply(str1, 3) : ', str2)
'''
str1 : PandaCode
np.char.multiply(str1, 3) : PandaCode PandaCode PandaCode
''' '''
3) numpy.char.center()
numpy.char.center() 用于居中字符串,其语法格式如下: np.char.center(string, width, fillchar)
string: 代表字符串,
width: 表示长度,
fillchar: 要填充的字符.
'''
print("----3) numpy.char.center()----")
str3 = 'PandaCode'
print('str3 : ', str3)
str4 = np.char.center(str3, 20, '*')
print('np.char.center(string, width, fillchar) : ', str4)
'''
str3 : PandaCode
np.char.center(string, width, fillchar) : *****PandaCode******
''' '''
4) numpy.char.capitalize()
numpy.char.capitalize() 将字符串的第一个字母转换为大写
'''
print("----4) numpy.char.capitalize()----")
print('numpy.char.capitalize() : ', np.char.capitalize('numpy'))
'''
numpy.char.capitalize() : Numpy
''' '''
5) numpy.char.title()
numpy.char.title() 将字符串数组中每个元素的第一个字母转换为大写
'''
print("----5) numpy.char.title()----")
print('numpy.char.title() : ', np.char.title("hello world"))
'''
numpy.char.title() : Hello World
''' '''
6) numpy.char.lower()
numpy.char.lower() 将字符串数组中每个元素转换为小写
'''
print("----6) numpy.char.lower()----")
print('numpy.char.lower() : ', np.char.lower("WELCOME TO China"))
'''
numpy.char.lower() : welcome to china
''' '''
7) numpy.char.upper()
numpy.char.upper() 将数组中的每个元素转换为大写
'''
print("----7) numpy.char.upper()----")
print('numpy.char.upper() : ', np.char.upper("welcome To china"))
'''
numpy.char.upper() : WELCOME TO CHINA
''' '''
8) numpy.char.split()
该函数通过指定分隔符对字符串进行分割,并返回数组序列。默认情况下,分隔符为空格。
'''
print("----8) numpy.char.split()----")
print('numpy.char.split() : ', np.char.split("hello world"), sep=" ")
'''
numpy.char.split() : ['hello', 'world']
''' '''
9) numpy.char.splitlines()
numpy.char.splitlines() 以换行符作为分隔符来分割字符串,并返回一个数组序列。
'''
print("----9) numpy.char.splitlines()----")
print('numpy.char.splitlines() : ', np.char.splitlines("welcome\nTo\nchina\n"))
'''
numpy.char.splitlines() : ['welcome', 'To', 'china']
''' '''
10) numpy.char.strip()
numpy.char.strip() 用于移除开头或结尾处的空格。
'''
print("----10) numpy.char.strip()----")
str5 = " Welcome To China "
print("原字符串 str5 : ", str5)
str6 = np.char.strip(str5)
print("np.char.strip(str5) : ", str6)
'''
原字符串 str5 : Welcome To China
np.char.strip(str5) : Welcome To China
''' '''
11) numpy.char.join()
numpy.char.join() 通过指定的分隔符来连接数组中的元素或字符串。
'''
print("----11) numpy.char.join()----")
print("numpy.char.join() : ", np.char.join('-', 'PandaCode'))
# 也可指定多个分隔符
print("numpy.char.join() : ", np.char.join([':', '*'], ['hello', 'world']))
'''
numpy.char.join() : P-a-n-d-a-C-o-d-e
numpy.char.join() : ['h:e:l:l:o' 'w*o*r*l*d']
''' '''
12) numpy.char.replace()
numpy.char.replace() 使用新字符替换字符串中的指定字符。
'''
print("----12) numpy.char.replace()----")
str7 = "Welcome to China"
print("原字符串 str7 : ", str7)
# 替换更改后字符串
print("numpy.char.replace() : ", np.char.replace(str7, "Welcome to", "Hello"))
'''
原字符串 str7 : Welcome to China
numpy.char.replace() : Hello China
''' '''
13) numpy.char.encode() 与 numpy.char.decode()
默认以utf-8的形式进行编码与解码
'''
print("----13) numpy.char.encode() 与 numpy.char.decode() ----")
# cp500国际编码
encode_str = np.char.encode("Hello World", 'cp500')
print("numpy.char.encode() : ", encode_str)
decode_str = np.char.decode(encode_str, 'cp500')
print("numpy.char.decode() : ", decode_str)
'''
numpy.char.encode() : b'\xc8\x85\x93\x93\x96@\xe6\x96\x99\x93\x84'
numpy.char.decode() : Hello World
''' '''
14, NumPy数学函数
NumPy 中包含了大量的数学函数,它们用于执行各种数学运算,其中包括三角函数、舍入函数等等。
'''
'''
(1) 三角函数
NumPy 中提供了用于弧度计算的的 sin()(正弦)、cos()(余弦)和 tan()(正切)三角函数。
'''
print("----14, NumPy数学函数----")
print("----(1) 三角函数----")
arr = np.array([0, 30, 60, 90, 120, 150, 180])
# 计算arr数组中给定角度的三角函数值
# 通过乘以np.pi/180将其转换为弧度
print("np.sin() : ", np.sin(arr * np.pi/180))
print("np.cos() : ", np.cos(arr * np.pi/180))
print("np.tan() : ", np.tan(arr * np.pi/180))
'''
np.sin() : [0.00000000e+00 5.00000000e-01 8.66025404e-01 1.00000000e+00
8.66025404e-01 5.00000000e-01 1.22464680e-16]
np.cos() : [ 1.00000000e+00 8.66025404e-01 5.00000000e-01 6.12323400e-17
-5.00000000e-01 -8.66025404e-01 -1.00000000e+00]
np.tan() : [ 0.00000000e+00 5.77350269e-01 1.73205081e+00 1.63312394e+16
-1.73205081e+00 -5.77350269e-01 -1.22464680e-16] 除了上述三角函数以外,NumPy 还提供了 arcsin,arcos 和 arctan 反三角函数。
'''
print("----反三角函数----")
# 若要想验证反三角函数的结果,可以通过 numpy.degrees() 将弧度转换为角度来实现
arr1 = np.array([0, 30, 60, 90])
print("arr1 : ", arr1)
# 正弦值数组
sinval = np.sin(arr1 * np.pi/180)
print("sinval : ", sinval)
# 计算角度反正弦,返回值以弧度为单位
cosec = np.arcsin(sinval)
print("cosec : ", cosec)
# 通过degrees函数转化为角度进行验证
print("np.degrees(cosec) : ", np.degrees(cosec))
#余弦值数组
cosval = np.cos(arr1 * np.pi/180)
print("cosval : ", cosval)
# 计算反余弦值,以弧度为单位
sec = np.arccos(cosval)
print("sec : ", sec)
# 通过degrees函数转化为角度进行验证
print("np.degrees(sec) : ", np.degrees(sec))
# 下面是tan()正切函数
tanval = np.tan(arr1 * np.pi/180)
print("tanval : ", tanval)
cot = np.arctan(tanval)
print("cot : ", cot)
print("np.degrees(cot) : ", np.degrees(cot))
'''
arr1 : [ 0 30 60 90]
sinval : [0. 0.5 0.8660254 1. ]
cosec : [0. 0.52359878 1.04719755 1.57079633]
np.degrees(cosec) : [ 0. 30. 60. 90.]
cosval : [1.00000000e+00 8.66025404e-01 5.00000000e-01 6.12323400e-17]
sec : [0. 0.52359878 1.04719755 1.57079633]
np.degrees(sec) : [ 0. 30. 60. 90.]
tanval : [0.00000000e+00 5.77350269e-01 1.73205081e+00 1.63312394e+16]
cot : [0. 0.52359878 1.04719755 1.57079633]
np.degrees(cot) : [ 0. 30. 60. 90.]
''' '''
(2) 舍入函数
NumPy 提供了三个舍入函数,介绍如下: 1) numpy.around()
该函数返回一个十进制值数,并将数值四舍五入到指定的小数位上。该函数的语法如下:
numpy.around(a,decimals) 参数说明:
a:代表要输入的数组;
decimals:要舍入到的小数位数。它的默认值为0,如果为负数,则小数点将移到整数左侧。
'''
print("----(2) 舍入函数----")
print("----1) numpy.around() ----")
arr2 = np.array([12.232, 90.26720, 163.620, 27.282])
print("原数组 arr2 : ", arr2)
print("数组值四舍五入到小数点后2位 : ", np.around(arr2, 2))
print("数组值四舍五入到小数点后1位 : ", np.around(arr2, 1))
print("数组值四舍五入到小数点后0位 : ", np.around(arr2))
print("数组值四舍五入到小数点后-1位 : ", np.around(arr2, -1))
'''
原数组 arr2 : [ 12.232 90.2672 163.62 27.282 ]
数组值四舍五入到小数点后2位 : [ 12.23 90.27 163.62 27.28]
数组值四舍五入到小数点后1位 : [ 12.2 90.3 163.6 27.3]
数组值四舍五入到小数点后0位 : [ 12. 90. 164. 27.]
数组值四舍五入到小数点后-1位 : [ 10. 90. 160. 30.]
''' '''
2) numpy.floor()
该函数表示对数组中的每个元素向下取整数,即返回不大于数组中每个元素值的最大整数。
'''
print("----2) numpy.floor()----")
arr3 = np.array([12.23, 90.26, 163.60, 27.2])
print("原数组 arr3 : ", arr3)
# 对数组向下取整
print("对数组向下取整, numpy.floor() : ", np.floor(arr3))
'''
原数组 arr3 : [ 12.23 90.26 163.6 27.2 ]
对数组向下取整, numpy.floor() : [ 12. 90. 163. 27.]
''' '''
3) numpy.ceil()
该函数与 floor 函数相反,表示向上取整。
'''
print("----3) numpy.ceil()----")
# 对数组向下取整
print("对数组向下取整, numpy.ceil() : ", np.ceil(arr3))
'''
对数组向下取整, numpy.ceil() : [ 13. 91. 164. 28.]
''' '''
15, NumPy算术运算
NumPy 数组的“加减乘除”算术运算,分别对应 add()、subtract()、multiple() 以及 divide() 函数。
注意:做算术运算时,输入数组必须具有相同的形状,或者符合数组的广播规则,才可以执行运算。
'''
print("----15, NumPy算术运算----")
print("----(1), NumPy数组的 加减乘除 算术运算----")
arr_a = np.arange(6, dtype=np.float_).reshape(2, 3)
# 数组a
print("arr_a : ", arr_a)
# 数组b
arr_b = np.array([2, 2, 2])
print("arr_b : ", arr_b)
# 数组加法运算
print("np.add() : ", np.add(arr_a, arr_b))
# 数组减法运算
print("np.subtract() : ", np.subtract(arr_a, arr_b))
# 数组乘法运算
print("np.multiply() : ", np.multiply(arr_a, arr_b))
# 数组除法运算
print("np.divide() : ", np.divide(arr_a, arr_b))
'''
arr_a : [[0. 1. 2.]
[3. 4. 5.]]
arr_b : [2 2 2]
np.add() : [[2. 3. 4.]
[5. 6. 7.]]
np.subtract() : [[-2. -1. 0.]
[ 1. 2. 3.]]
np.multiply() : [[ 0. 2. 4.]
[ 6. 8. 10.]]
np.divide() : [ [0. 0.5 1. ]
[1.5 2. 2.5]]
''' '''
(2) numpy.reciprocal()
该函数对数组中的每个元素取倒数,并以数组的形式将它们返回。 当数组元素的数据类型为整型(int)时,对于绝对值小于 1 的元素,返回值为 0,
而当数组中包含 0 元素时,返回值将出现 overflow(inf) 溢出提示。
'''
print("----(2) numpy.reciprocal()----")
# 注意此处有0
arr_a = np.array([0.25, 2.0, 1, 0, 10])
# 数组a默认为浮点类型数据
print("arr_a : ", arr_a)
# 对数组a使用求倒数操作
print("np.reciprocal(arr_a) : ", np.reciprocal(arr_a))
# b数组的数据类型为整形int
arr_b = np.array([100, 50, 20], dtype=int)
print("arr_b : ", arr_b)
# 对数组b使用求倒数操作
print("np.reciprocal(arr_b) : ", np.reciprocal(arr_b))
'''
arr_a : [ 0.25 2. 1. 0. 10. ]
np.reciprocal(arr_a) : [4. 0.5 1. inf 0.1]
arr_b : [100 50 20]
np.reciprocal(arr_b) : [0 0 0]
''' '''
(3) numpy.power()
该函数将 a 数组中的元素作为底数,把 b 数组中与 a 相对应的元素作幂 ,最后以数组形式返回两者的计算结果。
'''
print("----(3) numpy.power()----")
arr_a = np.array([2, 10, 20])
# a数组
print("arr_a : ", arr_a)
# 调用 power 函数
print("np.power(arr_a, 2) : ", np.power(arr_a, 2))
# b数组
arr_b = np.array([3, 2, 1])
print("arr_b : ", arr_b)
# 调用 power 函数
print("np.power(arr_a, arr_b) : ", np.power(arr_a, arr_b))
'''
arr_a : [ 2 10 20]
np.power(arr_a, 2) : [ 4 100 400]
arr_b : [3 2 1]
np.power(arr_a, arr_b) : [ 8 100 20]
''' '''
(4) numpy.mod()
返回两个数组相对应位置上元素相除后的余数,它与 numpy.remainder() 的作用相同 。
'''
print("----(4) numpy.mod()----")
arr_a = np.array([12, 23, 34])
print("arr_a : ", arr_a)
arr_b = np.array([3, 5, 7])
print("arr_b : ", arr_b)
# a与b相应位置的元素做除法
print("np.mod(arr_a, arr_b) : ", np.mod(arr_a, arr_b))
# remainder方法一样
print("np.remainder(arr_a, arr_b) : ", np.remainder(arr_a, arr_b))
'''
arr_a : [12 23 34]
arr_b : [3 5 7]
np.mod(arr_a, arr_b) : [0 3 6]
np.remainder(arr_a, arr_b) : [0 3 6]
''' '''
(5) 复数数组处理函数
NumPy 提供了诸多处理复数类型数组的函数,主要有以下几个:
numpy.real() 返回复数数组的实部;
numpy.imag() 返回复数数组的虚部;
numpy.conj() 通过更改虚部的符号,从而返回共轭复数;
numpy.angle() 返回复数参数的角度,该函数的提供了一个 deg 参数,
如果 deg=True,则返回的值会以角度制来表示,否则以以弧度制来表示。
'''
print("----(5) 复数数组处理函数----")
arr5 = np.array([-2.6j, 0.3j, 12. , 5+1j])
print("arr5 : ", arr5)
# numpy.real() 返回复数数组的实部;
print("np.real() : ", np.real(arr5))
# numpy.imag() 返回复数数组的虚部;
print("np.imag() : ", np.imag(arr5))
# numpy.conj() 通过更改虚部的符号,从而返回共轭复数;
print("np.conj() : ", np.conj(arr5))
# numpy.angle() 返回复数参数的角度
print("np.angle() : ", np.angle(arr5))
# numpy.angle() 返回复数参数的角度,deg=True,则返回的值会以角度制来表示
print("np.angle() : ", np.angle(arr5, deg=True))
'''
arr5 : [-0.-2.6j 0.+0.3j 12.+0.j 5.+1.j ]
np.real() : [-0. 0. 12. 5.]
np.imag() : [-2.6 0.3 0. 1. ]
np.conj() : [-0.+2.6j 0.-0.3j 12.-0.j 5.-1.j ]
np.angle() : [-1.57079633 1.57079633 0. 0.19739556]
np.angle() : [-90. 90. 0. 11.30993247]
'''

  

 

NumPy学习7的更多相关文章

  1. NumPy学习笔记 三 股票价格

    NumPy学习笔记 三 股票价格 <NumPy学习笔记>系列将记录学习NumPy过程中的动手笔记,前期的参考书是<Python数据分析基础教程 NumPy学习指南>第二版.&l ...

  2. NumPy学习笔记 二

    NumPy学习笔记 二 <NumPy学习笔记>系列将记录学习NumPy过程中的动手笔记,前期的参考书是<Python数据分析基础教程 NumPy学习指南>第二版.<数学分 ...

  3. NumPy学习笔记 一

    NumPy学习笔记 一 <NumPy学习笔记>系列将记录学习NumPy过程中的动手笔记,前期的参考书是<Python数据分析基础教程 NumPy学习指南>第二版.<数学分 ...

  4. 数据分析之Pandas和Numpy学习笔记(持续更新)<1>

    pandas and numpy notebook        最近工作交接,整理电脑资料时看到了之前的基于Jupyter学习数据分析相关模块学习笔记.想着拿出来分享一下,可是Jupyter导出来h ...

  5. NumPy学习(索引和切片,合并,分割,copy与deep copy)

    NumPy学习(索引和切片,合并,分割,copy与deep copy) 目录 索引和切片 合并 分割 copy与deep copy 索引和切片 通过索引和切片可以访问以及修改数组元素的值 一维数组 程 ...

  6. NumPy学习(让数据处理变简单)

    NumPy学习(一) NumPy数组创建 NumPy数组属性 NumPy数学算术与算数运算 NumPy数组创建 NumPy 中定义的最重要的对象是称为 ndarray 的 N 维数组类型. 它描述相同 ...

  7. numpy 学习笔记

    numpy 学习笔记 导入 numpy 包 import numpy as np 声明 ndarray 的几种方法 方法一,从list中创建 l = [[1,2,3], [4,5,6], [7,8,9 ...

  8. numpy 学习总结

    numpy 学习总结 作者:csj更新时间:01.09 email:59888745@qq.com 说明:因内容较多,会不断更新 xxx学习总结: 回主目录:2017 年学习记录和总结 #生成数组/使 ...

  9. (转)Python数据分析之numpy学习

    原文:https://www.cnblogs.com/nxld/p/6058572.html https://morvanzhou.github.io/tutorials/data-manipulat ...

  10. Numpy学习1

    NumPy学习(1) 参考资料: http://www.cnblogs.com/zhanghaohong/p/4854858.html http://linusp.github.io/2016/02/ ...

随机推荐

  1. 由于OpenCV的#include <opencv2/opencv.hpp>文件没有放在所有的头文件之前所引起的编译时提示很多错误,如:filesystem.hpp(11,12): error C2144: 语法错误:“bool”的前面应有“;”error C4430: 缺少类型说明符 - 假定为 int。注意: C++ 不支持默认 int等

    现象描述: 由于OpenCV的#include <opencv2/opencv.hpp>文件没有放在所有的其他OpenCV头文件之前所引起的编译时提示很多错误,如:filesystem.h ...

  2. Solution Set - “谁将重力悬空,坠入一场蔚蓝的梦”

    目录 0.「NOI Simu.」皮配 1.「BZOJ #4671」异或图 2.「CF 1158F」Density of subarrays 3.「CF 794G」Replace All 4.「UR # ...

  3. CDS标准视图:维修工单实际成本数据 I_MaintOrderActualCostDataCube

    视图名称:维修工单实际成本数据 I_MaintOrderActualCostDataCube 视图类型:基础 视图代码: 点击查看代码 @VDM.viewType: #COMPOSITE @AbapC ...

  4. w3cschool-Spring Security

    https://www.w3cschool.cn/springsecurity/na1k1ihx.html Spring Security,这是一种基于 Spring AOP 和 Servlet 过滤 ...

  5. Java 链表API

    Java 链表 1.什么是链表? 链表是一种物理存储单元上非连续.非顺序的存储结构,数据元素的逻辑顺序是通过链表中的指针连接次序实现的. 每一个链表都包含多个节点,节点又包含两个部分: 1)一个是数据 ...

  6. 从零开始构建一个gradle工程

    gradle init --type java-application 首先,确保您已经安装了Java和Gradle.您可以从官方网站下载并按照说明进行安装. 创建一个新的项目文件夹,并进入该文件夹. ...

  7. 理解ABP的领域驱动设计

    大家好,我是张飞洪,感谢您的阅读,我会不定期和你分享学习心得,希望我的文章能成为你成长路上的垫脚石,让我们一起精进. 关于玩转ABP框架相关的文章,之前在博客园陆续写了<ABP vNext系列文 ...

  8. 认识soui4js(第1篇)

    源代码:https://github.com/soui4js/soui4js soui4js是soui4+quickjs的结合体. soui4是一套c++ directui客户端开发框架,soui4j ...

  9. mac spark+hive+hadoop 数据分析环境搭建(单机简版)

    apache产品下载地址: http://archive.apache.org/dist/ mysql5.6 brew方式安装配置: Icon   mysql做为元数据存储使用. brew searc ...

  10. RabbitMQ(八)——消息确认

    RabbitMQ系列 RabbitMQ(一)--简介 RabbitMQ(二)--模式类型 RabbitMQ(三)--简单模式 RabbitMQ(四)--工作队列模式 RabbitMQ(五)--发布订阅 ...