首页 > 编程语言 >软件测试|Python科学计算神器numpy教程(二)

软件测试|Python科学计算神器numpy教程(二)

时间:2023-08-06 17:36:25浏览次数:35  
标签:Python dtype 如下 print 数组 np numpy 软件测试

前言

上一篇文章我们介绍了numpy的安装和ndarray的部分知识,本篇文章我们来介绍一下numpy的数组的常用属性以及创建数组相关内容。

数组常用属性

  1. ndarray.shape

shape 属性的返回值一个由数组维度构成的元组,比如 2 行 3 列的二维数组可以表示为(2,3),该属性可以用来调整数组维度的大小,示例如下:

import numpy as np
a = np.array([[2,4,6],[3,5,7]])
print(a.shape)

-------------------
输出结果如下:
(2, 3)

当然我们也可以通过shape属性修改数组的形状大小:

import numpy as np
a = np.array([[1,2,3],[4,5,6]])
a.shape = (3,2)
print(a)

----------------
输出结果如下:

[[1 2]
 [3 4]
 [5 6]]
  1. ndarray.reshape()

reshape() 函数可以调整数组形状,示例如下:

import numpy as np
a = np.array([[1,2,3],[4,5,6]])
b = a.reshape(3,2)
print(b)

--------------------
输出结果如下:
[[1 2]
 [3 4]
 [5 6]]
  1. ndarray.ndim

上一篇文章已经介绍了,这个方法返回的是数组的维数,示例如下:

import numpy as np
#随机生成一个一维数组
c = np.arange(24)
print(c)
print(c.ndim)
#对数组进行变维操作
e = c.reshape(2,4,3)
print(e)
print(e.ndim)

------------------------
输出结果如下:
[ 0  1  2  3  4  5  6  7  8  9 10 11 12 13 14 15 16 17 18 19 20 21 22 23]
1
[[[ 0  1  2]
  [ 3  4  5]
  [ 6  7  8]
  [ 9 10 11]]

 [[12 13 14]
  [15 16 17]
  [18 19 20]
  [21 22 23]]]
3
  1. ndarray.itemsize

返回数组中每个元素的大小(以字节为单位),示例如下:

#数据类型为int8,代表1字节
import numpy as np
x = np.array([1,2,3,4,5], dtype = np.int8)
print (x.itemsize)

---------------------
输出结果如下:
1
#数据类型为int64,代表8字节

import numpy as np
x = np.array([1,2,3,4,5], dtype = np.int64)
print (x.itemsize)

-------------------------
输出结果如下:
8
  1. ndarray.flags

返回 ndarray 数组的内存信息,比如 ndarray 数组的存储方式,以及是否是其他数组的副本等,示例如下:

import numpy as np
x = np.array([1,2,3,4,5])
print (x.flags)

------------------
输出结果如下:
 C_CONTIGUOUS : True
  F_CONTIGUOUS : True
  OWNDATA : True
  WRITEABLE : True
  ALIGNED : True
  WRITEBACKIFCOPY : False
  UPDATEIFCOPY : False

创建数组

之前我们介绍了使用array()方法创建数组,现在我们介绍其他几个创建数组的方法。

  1. numpy.empty()

numpy.empty() 创建未初始化的数组,可以指定创建数组的形状(shape)和数据类型(dtype),语法格式如下:

numpy.empty(shape, dtype = float, order = 'C')

参数说明:

  • shape:指定数组的形状
  • dtype:数组元素的数据类型,默认值是值 float
  • order:指数组元素在计算机内存中的储存顺序,默认顺序是“C”(行优先顺序)

示例如下:

import numpy as np
arr = np.empty((4,2), dtype = int)
print(arr)

--------------------------
输出结果如下:
[[  385967105 -2113830144]
 [ 2080601089 -2097118463]
 [  687887105    17654018]
 [  537526272  1344282656]]

注:numpy.empty()创建的数组并不是空数组,而是带有随机值的数组,这些值没有任何意义

  1. numpy.zeros()

numpy.zeros()创建元素均为 0 的数组,同时还可以指定被数组的形状,语法格式如下:

numpy. zeros(shape,dtype=float,order="C")

参数说明:

  • shape:指定数组的形状大小
  • dtype:可选项,数组的数据类型
  • order:“C”代表以行顺序存储,“F”则表示以列顺序存储

示例如下:

import numpy as np
#默认数据类型为浮点数
a=np.zeros(6)
print(a)

-------------------
输出结果如下:
[0. 0. 0. 0. 0. 0.]
  1. numpy.ones()

numpy.ones()指定形状大小与数据类型的新数组,并且新数组中每项元素均用 1 填充,语法格式如下:

numpy.ones(shape, dtype = None, order = 'C')
import numpy as np
arr1 = np.ones((3,2), dtype = int)
print(arr1)

-----------------
输出结果如下:
[[1 1]
 [1 1]
 [1 1]]
  1. numpy.asarray()

asarray() 与 array() 类似,但是它比 array() 更为简单。asarray() 能够将一个 Python 序列转化为 ndarray 对象,语法格式如下:

numpy.asarray(sequence,dtype = None ,order = None )

参数说明:

  • sequence:接受一个 Python 序列,可以是列表或者元组
  • dtype:可选参数,数组的数据类型
  • order:数组内存布局样式,可以设置为 C 或者 F,默认是 C

示例如下:

# 列表转化为 numpy 数组

import numpy as np
l=[1,2,3,4,5,6,7]
a = np.asarray(l);
print(type(a))
print(a) 
--------------------
输出结果如下:
<class 'numpy.ndarray'>
[1 2 3 4 5 6 7]


# 使用元组创建 numpy 数组

import numpy as np 
t=(1,2,3,4,5,6,7)    
a = np.asarray(t); 
print(type(a)) 
print(a)  

----------------
输出结果如下:
<class 'numpy.ndarray'>
[1 2 3 4 5 6 7]


# 使用嵌套列表创建多维数组

import numpy as np
l=[[1,2,3,4,5,6,7],[8,9]]
a = np.asarray(l, dtype=object);
print(type(a))
print(a)

------------------
输出结果如下:
<class 'numpy.ndarray'>
[list([1, 2, 3, 4, 5, 6, 7]) list([8, 9])]
  1. numpy.frombuffer()

使用指定的缓冲区创建数组,语法如下:

numpy.frombuffer(buffer, dtype = float, count = -1, offset = 0)

参数说明:

  • buffer:将任意对象转换为流的形式读入缓冲区
  • dtype:返回数组的数据类型,默认是 float32
  • count:要读取的数据数量,默认为 -1 表示读取所有数据
  • offset:读取数据的起始位置,默认为 0

示例如下:

import numpy as np
#字节串类型
l = b'hello world'
print(type(l))
a = np.frombuffer(l, dtype = "S1")
print(a)
print(type(a))

---------------------
输出结果如下:
<class 'bytes'>
[b'h' b'e' b'l' b'l' b'o' b' ' b'w' b'o' b'r' b'l' b'd']
<class 'numpy.ndarray'> 
  1. numpy.fromiter()

把迭代对象转换为 ndarray 数组,其返回值是一个一维数组,语法如下:

numpy.fromiter(iterable, dtype, count = -1)

参数说明:

  • iterable:可迭代对象
  • dtype:返回数组的数据类型
  • count:读取的数据数量,默认为 -1,读取所有数据

示例:

import numpy as np
# 使用 range 函数创建列表对象
list=range(7)
#生成可迭代对象i
i=iter(list)
#使用i迭代器,通过fromiter方法创建ndarray
array=np.fromiter(i, dtype=float)
print(array)

----------------------
输出结果如下:
[0. 1. 2. 3. 4. 5. 6.]

总结

本文主要介绍array的内置属性以及创建array的不同方法,我们需要尤其注意使用numpy.empty()创建数组时,创建的数组并不是一个空的数组,我们使用空方法,但生成的不是空数组。

标签:Python,dtype,如下,print,数组,np,numpy,软件测试
From: https://www.cnblogs.com/hogwarts/p/17609613.html

相关文章

  • 软件测试|web自动化测试神器playwright教程(十七)
    前言上篇文章我们介绍了使用playwright下载文件的方法,本篇文章我们将介绍使用playwright上传文件。上传文件是我们经常需要面对的场景,如果我们使用的是selenium,那我们的操作会比较复杂,因为有的文件上传是input控件,有些是需要我们直接传文件地址,一旦弹出文件选择框的话,selenium就......
  • 软件测试|web自动化测试神器playwright教程(二十)
    前言我们都知道,selenium可以实现Chrome浏览器的复用,绕过登录步骤,实现cookie的复用,playwright同样也可以实现该功能。环境设置我们在使用selenium进行浏览器复用时,需要提前将Chrome浏览器配置到我们的环境变量中,具体步骤如下:找到Chrome浏览器的安装路径,如下图:将'C:\Progra......
  • 软件测试|web自动化测试神器playwright教程(二十三)
    前言我们在进行web自动化时,经常遇到一些不好操作的元素,普通的元素定位和操作容易报错,如果我们使用的selenium的话,就可以使用selenium调用js脚本进行操作。在playwright中也有类似的方法,使用page.evaluate()执行JavaScript脚本。page.evaluate()和page.evaluate_handle()之间的......
  • 软件测试|web自动化测试神器playwright教程(二十二)
    前言工作和生活中,经常会遇到我们需要进行选择的情况,比如勾选,或者我们选择性别,男女两个性别总是不能同时选中的,比如我们在选择兴趣爱好时,我们可以选择多个自己感兴趣的话题,比如篮球足球电竞等话题。我们在执行自动化测试的过程中,必须要学会处理这样的情况。页面示例以下面的界面......
  • 软件测试|web自动化测试神器playwright教程(二十四)
    前言我们在使用selenium进行自动化测试的过程中,遇到输入框时,我们可以使用send_keys()输入内容,也可以使用键盘事件向输入框内输入内容,只是使用键盘事件时需要导入Keys,作为一款强大的工具,selenium有的功能,playwright也有,playwright同样可以使用键盘输入内容,本篇文章就来为大家介绍一......
  • 软件测试|web自动化测试神器playwright教程(二十五)
    前言鼠标为我们使用电脑提供了很多方便,我们看到的东西就可以将鼠标移动过去进行点击就可以打开或者访问内容,当页面内容过长时,我们也可以使用鼠标滚轮来实现对整个页面内容的查看,其实playwright也有鼠标操作的方法,本文我们就来介绍playwright的鼠标操作。鼠标操作Mouse鼠标操......
  • 软件测试|没有任何文档,怎么快速了解接口的信息?
    没有接口文档的情况下理解接口信息,通过询问开发,或查看代码来了解接口。当然最重要的是利用接口本身提供的一切可见的细节,比如:URL、请求方法、参数、响应结果等,尽量去推断和判断接口的功能与作用。多种手段结合,观察分析,通常可以比较快速地理解接口的信息。需要注意的是:在了解接口的......
  • 软件测试|web自动化测试神器playwright教程(二十六)
    前言我们使用selenium进行元素拖拽时,通常要使用ActionChains来实现drag_and_drop的操作,playwright同样可以实现元素的拖拽和释放的操作。按住元素从页面的一个位置拖动到另外一个位置,有2种方式可以实现locator.drag_to(target:locator)先定位元素,调用drag_to方法到目标元素......
  • 数据量较大时,python 如何加速 matplotlib 的作图
    数据量较大时,python如何加速matplotlib的作图?GeneratedbyChatGPT当数据量较大时,matplotlib可能会变得缓慢。下面是一些可以加速matplotlib作图的方法:使用blitting:blitting是一种将图形上下文缓存到位图中的技术,可以提高图形更新的速度。使用数据抽样:通过对数据进行抽......
  • python基础入门模块
    一、os模块os模块提供了许多与操作系统相关的函数,可以让我们在Python程序中轻松地处理文件和目录、环境变量等等。下面是os模块中常用的方法:os.getcwd()这个函数用于获取当前工作目录,即当前Python脚本工作的目录路径。os.chdir(path)这个函数用于改变当前工作目录到指定的......