NumPy学习7
今天学习了:
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的更多相关文章
- NumPy学习笔记 三 股票价格
NumPy学习笔记 三 股票价格 <NumPy学习笔记>系列将记录学习NumPy过程中的动手笔记,前期的参考书是<Python数据分析基础教程 NumPy学习指南>第二版.&l ...
- NumPy学习笔记 二
NumPy学习笔记 二 <NumPy学习笔记>系列将记录学习NumPy过程中的动手笔记,前期的参考书是<Python数据分析基础教程 NumPy学习指南>第二版.<数学分 ...
- NumPy学习笔记 一
NumPy学习笔记 一 <NumPy学习笔记>系列将记录学习NumPy过程中的动手笔记,前期的参考书是<Python数据分析基础教程 NumPy学习指南>第二版.<数学分 ...
- 数据分析之Pandas和Numpy学习笔记(持续更新)<1>
pandas and numpy notebook 最近工作交接,整理电脑资料时看到了之前的基于Jupyter学习数据分析相关模块学习笔记.想着拿出来分享一下,可是Jupyter导出来h ...
- NumPy学习(索引和切片,合并,分割,copy与deep copy)
NumPy学习(索引和切片,合并,分割,copy与deep copy) 目录 索引和切片 合并 分割 copy与deep copy 索引和切片 通过索引和切片可以访问以及修改数组元素的值 一维数组 程 ...
- NumPy学习(让数据处理变简单)
NumPy学习(一) NumPy数组创建 NumPy数组属性 NumPy数学算术与算数运算 NumPy数组创建 NumPy 中定义的最重要的对象是称为 ndarray 的 N 维数组类型. 它描述相同 ...
- numpy 学习笔记
numpy 学习笔记 导入 numpy 包 import numpy as np 声明 ndarray 的几种方法 方法一,从list中创建 l = [[1,2,3], [4,5,6], [7,8,9 ...
- numpy 学习总结
numpy 学习总结 作者:csj更新时间:01.09 email:59888745@qq.com 说明:因内容较多,会不断更新 xxx学习总结: 回主目录:2017 年学习记录和总结 #生成数组/使 ...
- (转)Python数据分析之numpy学习
原文:https://www.cnblogs.com/nxld/p/6058572.html https://morvanzhou.github.io/tutorials/data-manipulat ...
- Numpy学习1
NumPy学习(1) 参考资料: http://www.cnblogs.com/zhanghaohong/p/4854858.html http://linusp.github.io/2016/02/ ...
随机推荐
- Qt音视频开发47-通用视频控件
一.前言 自从视频监控系统的内核不断增加,从最初的vlc到ffmpeg然后到mpv,后面还陆续增加了海康sdk等,每次增加一个内核,整个视频监控系统就有三五个代码文件需要修改,而且大部分是重复的代码, ...
- 解决pip命令报错及Python环境配置指南:从安装到优化
1. 错误日志 当我在 Linux 机器(使用 Debian 或 Ubuntu 或衍生发行版)上运行 pip install xyz 时,会出现这样的错误: error: externally-man ...
- IM跨平台技术学习(十一):环信基于Electron打包Web IM桌面端的技术实践
本文由环信技术黄飞鹏分享,原题"实战|如何利用 Electron 快速开发一个桌面端应用",本文进行了排版和内容优化等. 1.引言 早就听说利用Electron可以非常便捷的将网页 ...
- Java子线程无法获取Attributes的解决方法
在Java多线程编程中,开发者经常会遇到子线程无法获取主线程设置的Attributes的问题.Attributes通常用于存储与当前线程相关的数据,尤其在Web应用中,它们常用于请求上下文的管理.然而 ...
- Windows Terminal 智能提示
安装PSReadLine Install-Module -Name PSReadLine -AllowClobber -Force 打开$profile notepad $profile 配置补全 在 ...
- asp.net mvc中换肤机制类库 ThemedViewEngines
制作blog系统或者通用cms系统的时候,我们经常会用到Theme功能.asp.net mvc中的一种实现方式,是继承实现RazorViewEngine即可. 这是在GitHub中找到的一个示例:ht ...
- ls小技巧
一.ls -rt ls的功能是列出指定路径下的所有文件,但是有时候文件太多,不方便查找哪些是新生成的文件时,可以使用ls -t或ls -rt命令. ls -t ls -rt 那是什么意思呢?这里-t就 ...
- C# webapi 允许跨域(.NET Framework)
实际项目中,对于WebApi的访问不一定都在同一域名下,所以进行跨域访问的时候,可能会出现如下提示:请求的资源不支持 http 方法"OPTIONS".需要对WebApi进行设置. ...
- ctfshow--web10 php代码逻辑漏洞with rollup注入
dirsearch没有扫到文件 查看源代码发现 有个style.css文件点击查看 查看index.phps代码 又是代码审计 点击查看代码 <?php $flag=""; ...
- manim边做边学--淡入淡出变换
今天介绍Manim中用于淡入淡出变换的3个动画类: FadeToColor:聚焦于对象颜色的平滑转换,通过渐变增强视觉效果 FadeTransform:实现不同对象之间的渐变替换,让元素转换更加连贯 ...