Numpy np.array()函数使用方法指南
作者:请你喝奶茶~ 发布时间:2023-05-23 09:33:37
标签:nnumpy,np.array(),函数
1、Numpy ndarray对象
numpy ndarray对象是一个n维数组对象,ndarray只能存储一系列相同元素。
#一维数组
[1,2,3,4]#shape(4,)
#二维数组
[[1,2,3,4]]#shape(1,4)
[[1,2,3,4],
[5,6,7,8]]#shape(2,4)
#三维数组
[
[[1,2,3],[4,5,6]],
[[7,8,9],[10,11,12]]
]#shape(2,2,3)
2、创建numpy数组
numpy.array()使用说明:object是必须输入的参数,其余为可选参数。
import numpy as np
np.array(object,dtype,copy=True,order,ndmin,subok=Fasle)
#object: 一个数组序列,例如[1,2,3,4]
#dtype: 更改数组内的数据类型
#copy: 数据源是ndarray时数组能否被复制,default=True
#order: 选择数组的内存布局,C(行序列)|F(列序列)|A(默认)
#ndmin: 数组维度
#subok: bool类型,True,使用object的内部数据类型;False,使用object的数组的数据类型,default=Fasle
创建存储元素类型不同的数组:
#int型
import numpy as np
a=np.array([1,2,3,4],dtype=int)#"dtype="可省略
print(a)
a.dtype
'''
输出:
[1 2 3 4]
dtype('int32')
'''
#float型
b=np.array([1,2,3,4],dtype=float)
print(b)
b.dtype
'''
输出:
[1. 2. 3. 4.]
dtype('float64')
'''
创建生成器:
a=np.array([i*10 for i in range(10)])
print(a)
b=np.array([i+2 for i in range(10)])
print(b)
'''
输出:
[ 0 10 20 30 40 50 60 70 80 90]
[ 2 3 4 5 6 7 8 9 10 11]
'''
当输入的object元素有不同类型时,将保留存储空间最大的类型:
x1=np.array([1,2,3,4,5.1])
print(x1)
x2=np.array([1,2,3,'a'])
print(x2)
x3=np.array([1,2.1,'a'])
print(x3)
'''
输出:
[1. 2. 3. 4. 5.1]
['1' '2' '3' 'a']
['1' '2.1' 'a']
'''
当多维数组元素个数不一致时:
x=np.array([[1,2,3],[1,2,3,4],[1,2,3,4,5]],dtype=object) #存储长度不一致序列时,应有“dtype=object”,否则会报错
print(x)
print(x.shape)
print(x.ndim)#输出数组的维度,2Darray强制转换成1Darray
'''
输出:
[list([1, 2, 3]) list([1, 2, 3, 4]) list([1, 2, 3, 4, 5])]
(3,)
1
'''
float强制转化int(向下取整):
a=np.array([1,2,3.1],int)
b=np.array([1,2,3.7],int)
print(a)
print(b)
'''
输出:
[1 2 3]
[1 2 3]
'''
用copy参数定义是否创建副本:
#默认copy=True情况下,复制创建x1的副本为x2
x1=np.array([1,2,3])
x2=np.array(x1)
print('x1 ',id(x1),'x2',id(x2))
#更改x2的值,x1的值不会发生改变,反之,修改x1的值,x2也不会发生改变,因为二者地址不同
x2[2]=100
print('x1',x1)
print('x2',x2)
'''
输出:
x1 2055556179312 x2 2055300844976 x1 x2地址不同
x1 [1 2 3]
x2 [ 1 2 100]
'''
#copy=Fasle情况下,复制创建x1的副本为x2
x1=np.array([1,2,3])
x2=np.array(x1,copy=False)
print('x1 ',id(x1),'x2',id(x2))
#更改x2的值,x1的值会发生改变,且x1永远等于x2,因为二者地址相同
x2[2]=100
print('x1',x1)
print('x2',x2)
'''
输出:
x1 2055300125584 x2 2055300125584 x1 x2地址相同
x1 [ 1 2 100]
x2 [ 1 2 100]
'''
#另一种创建副本方法:copy() 这种方法更常用
x1=np.array([1,2,3])
x2=x1.copy()
print('x1 ',id(x1),'x2',id(x2))
#更改x2的值,x1的值不会发生改变
x2[2]=100
print('x1',x1)
print('x2',x2)
'''
输出:
x1 2055556233040 x2 2055556062160
x1 [1 2 3]
x2 [ 1 2 100]
'''
ps:如果直接用 x2=x1 的形式复制array,此时x1 x2 共用同一个地址
用ndmin改变数组维度(升维有效,降维无效):
a=np.array([1,2,3,4],ndmin=2)
print('a ',a)
b=np.array([[1,2],[1,2]],ndmin=3)
print('b ',b)
#2D降维成1D,但输出结果仍为2D
c=np.array([[1,2],[1,2]],ndmin=1)
print('c ',c)
'''
输出:
a [[1 2 3 4]]
b [[[1 2]
[1 2]]]
c [[1 2]
[1 2]]
'''
用subok参数(bool值)确定数据类型:
x1=np.mat([1,2,3])
a1=np.array(x1) #存储为原类型
b1=np.array(x1,subok=True) #存储为数组类型
print('x1 ',type(x1),'a1 ',type(a1),'b1 ',type(b1))
#原始格式为list,无论subok为何值都转换成数组类型
x2=[[1,2],[1,2],[1]]
a2=np.array(x2,dtype=object) #存储为原类型
b2=np.array(x2,dtype=object,subok=True) #存储为数组类型
print('x2 ',type(x2),'a2 ',type(a2),'b2 ',type(b2))
'''
输出:
x1 <class 'numpy.matrix'> a1 <class 'numpy.ndarray'> b1 <class 'numpy.matrix'>
x2 <class 'list'> a2 <class 'numpy.ndarray'> b2 <class 'numpy.ndarray'>
'''
来源:https://blog.csdn.net/weixin_47097527/article/details/127649907


猜你喜欢
- 1.今天复习一下Vue自定义指令的代码,结果出现一个很无语的结果,先贴代码。2.<div id="example"
- 本文实例讲述了python实现生成Word、docx文件的方法。分享给大家供大家参考,具体如下:http://python-docx.rea
- 前言pyinstaller能够在Windows、Linux等操作系统下将Python脚本打包成可直接运行程序。使Python脚本
- 话说本来我的电脑有个2000的数据库,去年我在那个电脑上新装了一个2005的数据库。前不久我买了台新电脑,装了数据库2008 将在旧电脑上的
- 很神奇的一个晚上,居然在以前老同事的群里跟同事讨论起CSS的东西来了,不过很意外的还是有收获。在IE中常常会碰到如果将容器定位后,出现容器内
- z-blog摘要图文混排,在月光的博客早已有介绍,但是他的图文混排是基于一篇文章只定义一个Tag的情况,对于我这样习惯多tag的博客,再更改
- 前言最近在评估项目时,要开启评估平台,查看平台和保存平台,感觉非常繁琐,开发了一款可以获取评估平台数据,查看项目排期和直接保存数据到数据库的
- 这是Pyhon系列文章的第二篇,本文主要介绍如何运行Python程序以及安装PyCharm开发工具。干货满满,建议收藏,需要用到时常看看。
- 前言有的时候我们在查看数据库数据时,会看到乱码。实际上,无论何种数据库只要出现乱码问题,这大多是由于数据库字符集设定的问题。下面我们就介绍一
- 本文实例总结了Python字典常见操作。分享给大家供大家参考,具体如下:简单的字典:字典就是键值对key-value组合。#字典 键值对组合
- mysql 5.7.19 winx64安装教程记录如下,分享给大家step1官方下载地址:https://dev.mysql.com/dow
- show parameter processes; 然后 更改系统连接数 alter system set processes=1000 s
- 传递函数创建传递函数有两种方式:import control as ctrl# 方式 1s = ctrl.tf('s')sy
- 1.mysql复制概念 指将主数据库的DDL和DML操作通过二进制日志传到复制服务器上,然后在复制服务器上将这些日志文件重新执行
- 键盘事件废话不多说直接上包from selenium.webdriver.common.keys import Keys1、删除键 BACK
- 问题记录一下出现的问题, 数据翻倍这是复现问题的代码data() { return { space: "
- 目录1.爬虫文件2.items.py3.pipelines.py4.进行持久化存储之前我们使用lxml对梨视频网站中的视频进行了下载,感兴趣
- 一、python中对文件、文件夹操作时经常用到的os模块和shutil模块常用方法。1.得到当前工作目录,即当前Python脚本工作的目录路
- 前言对程序员来说,‘python’ 和’python ’看起
- 关于一些代码里的解释,可以看我上一篇发布的文章,里面有很详细的介绍!!!可以依次把下面的代码段合在一起运行,也可以通过jupyter not