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/ ...
随机推荐
- [转]VS2019生成项目文件.lib或.dll或exe后如何拷贝到指定的目录文件夹
VS2019编译CloudCompare,发现生成的项目文件都是分开的,每个项目下都有自己的文件夹Debug/Release,生成Dll都放在这些单独的项目文件夹内. 目标 (1)通常,我们要求所有的 ...
- 不为人知的网络编程(十五):深入操作系统,一文搞懂Socket到底是什么
1.引言 我相信大家刚开始学网络编程中socket的时候,都跟我一样对书上所讲的socket概念云里雾里的.似懂非懂,很是困扰. 这篇文章我打算从初学者的角度,用通俗易懂的文字,跟大家分享下我所理解的 ...
- 【Java 温故而知新系列】基础知识-03 基本类型对应之包装类
1.包装类都有哪些? 基本类型都有对应的包装类型,这些包装类提供了一种面向对象的方式来处理基本数据类型,允许它们被用于需要对象的场景,如集合框架.泛型等. 对应关系: 基本类型 包装类型 boolea ...
- 自动化滑动极验v3示例
import random import ddddocr from playwright.sync_api import sync_playwright import time import requ ...
- ClickHouse介绍-示例
示例 GitHub 事件数据集 数据集包含了GitHub上从2011年到2020年12月6日的所有事件,大小为31亿条记录.下载大小为75 GB,如果存储在使用lz4压缩的表中,则需要多达200 GB ...
- weixueyuan-Nginx负载均衡7
https://www.weixueyuan.net/nginx/load_balanc/ Nginx负载均衡模块简述 Nginx 负载均衡是由代理模块和上游(upstream)模块共同实现的,Ngi ...
- 131:在红帽Linux中获得帮助
- 3090 cuda环境配置杂记
实验室新配了3090的电脑,cuda环境配置上出了些问题,百度很久才找到解决方法,因此记录下来. 主要参考:(6条消息) 服务器Linux环境配置cuda(非管理员)_@@Lynn的博客-CSDN博客 ...
- C# Newtonsoft.Json JObject常用方法
1.创建-用匿名对象创建 JObject JObject ob = JObject.FromObject(new { RPT_ID = "getList", pageSize = ...
- 干掉visio,这个画图神器真的绝了!!!
前言 看过我以往文章的小伙伴可能会发现,我的大部分文章都有很多配图.我的文章风格是图文相结合,更便于大家理解. 最近有很多小伙伴发私信问我:文章中的图是用什么工具画的.他们觉得我画的图风格挺小清新的, ...