1.使用array()函数创建数组

参数可以为:单层或嵌套列表;嵌套元组或元组列表;元组或列表组成的列表

# 导入numpy库
import numpy as np
# 由单层列表创建
a = np.array([1, 2, 3])
print(a)
[1 2 3]
# 由嵌套列表创建
b = np.array([[1.3, 2.4], [0.3, 4.1]])
print(b)
[[1.3 2.4]
 [0.3 4.1]]
# 由嵌套元组创建
c = np.array((("p", "y", "t"), ("h", "o", "n")))
print(c)
[['p' 'y' 't']
 ['h' 'o' 'n']]
# 由元组列表创建
d = np.array([(3, 2, 1), (7, 8, 9)])
print(d)
[[3 2 1]
 [7 8 9]]
# 由元组或列表组成的列表
e = np.array([(6, 1, 8), [7, 5, 3], (2, 9, 4)])
print(e)
[[6 1 8]
 [7 5 3]
 [2 9 4]]
# array创建数组返回的类型
print(type(a))
<class 'numpy.ndarray'>

2.数据类型

# 数组元素是同质的,即类型和大小都相同
# 数据类型由dtype对象来指定
# itemsize属性,定义了数组中每个元素的长度占几个字节
print(a.dtype.name, a.itemsize)
print(b.dtype.name, b.itemsize)
print(c.dtype.name, c.itemsize)
print(d.dtype.name, d.itemsize)
print(e.dtype.name, e.itemsize)

# array()函数默认根据列表或元素序列中各元素的数据类型,为ndarray对象指定最适合的数据类型。
# 也可以使用dtype选项作为array()的参数,明确指定dtype的类型。
# 如下定义一个复数数组
f = np.array([[1, 2, 3], [4, 5, 6]], dtype=complex)
print("-------------------------")
print(f)
int32 4
float64 8
str32 4
int32 4
int32 4
-------------------------
[[1.+0.j 2.+0.j 3.+0.j]
 [4.+0.j 5.+0.j 6.+0.j]]

3.NumPy库自带的数组创建方法

# zeros()函数生成由shape参数指定维度信息,元素均为0的数组。
# 元素的数据类型为float64
g = np.zeros((3, 3))
print(g)
[[0. 0. 0.]
 [0. 0. 0.]
 [0. 0. 0.]]
# ones()函数与上述函数相似
# 元素的数据类型为float64
h = np.ones((3, 3))
print(h)
[[1. 1. 1.]
 [1. 1. 1.]
 [1. 1. 1.]]
# arange()函数,按特定规则生成包含一个数值序列的数组。
# arange(begin, end, step)
# 参数begin省略则从0开始
# 参数end应该比序列最后一个值大
# 参数step可以是浮点型
i = np.arange(0, 10)
j = np.arange(10)
k = np.arange(4, 10)
m = np.arange(0, 10, 2)
n = np.arange(0, 10, 1.3)
print(i)
print("-------------------------")
print(j)
print("-------------------------")
print(k)
print("-------------------------")
print(m)
print("-------------------------")
print(n)
[0 1 2 3 4 5 6 7 8 9]
-------------------------
[0 1 2 3 4 5 6 7 8 9]
-------------------------
[4 5 6 7 8 9]
-------------------------
[0 2 4 6 8]
-------------------------
[0.  1.3 2.6 3.9 5.2 6.5 7.8 9.1]
# 结合reshape()函数进行拆分
x1 = np.arange(0, 12).reshape(3, 4)
print(x1)
[[ 0  1  2  3]
 [ 4  5  6  7]
 [ 8  9 10 11]]
# linspace(begin, end, cnt)函数
# 第三个参数表示需要将begin和end范围分成几个部分
x2 = np.linspace(0, 10 , 6)
print(x2)
[ 0.  2.  4.  6.  8. 10.]
# random()函数以随机数填充数组
# 每次生成元素均会有所不同
x3 = np.random.random(3)
x4 = np.random.random((3, 3))
print(x3)
print("------------------------------------------")
print(x4)
[0.8223299  0.83657551 0.797519  ]
------------------------------------------
[[0.14562367 0.8657818  0.96508416]
 [0.15094085 0.27332193 0.52784433]
 [0.0260834  0.3047311  0.65182433]]
#eye(N)函数创建一个NxN单位矩阵(对角线为1,其余为0)
x5 = np.eye(4)
print(x5)
[[1. 0. 0. 0.]
 [0. 1. 0. 0.]
 [0. 0. 1. 0.]
 [0. 0. 0. 1.]]
# 使用empty()函数返回全0数组的想法是不安全的
x6 = np.empty((2,3))
print(x6)
[[1. 2. 3.]
 [4. 5. 6.]]

NumPy学习_00 ndarray的创建的更多相关文章

  1. NumPy学习_02 ndarray基本操作

    1.算术运算符 它们只用于位置相同的元素之间,即为元素级的运算. 所得到的运算结果组成一个新的数组. 不用编写循环即可对数据执行批量运算.(矢量化) import numpy as np # 创建一个 ...

  2. NumPy学习_01 ndarray相关概念

    1.NumPy库 NumPy = Numerical Python 是高性能科学计算和数据分析的基础库. pandas库充分借鉴了NumPy的相关概念,先行掌握NumPy库的用法,才能把pandas的 ...

  3. Python数据分析:Numpy学习笔记

    Numpy学习笔记 ndarray多维数组 创建 import numpy as np np.array([1,2,3,4]) np.array([1,2,3,4,],[5,6,7,8]) np.ze ...

  4. Numpy学习之——数组创建

    Numpy学习之--数组创建 过程展示 import numpy as np a = np.array([2,3,9]) a array([2, 3, 9]) a.dtype dtype('int32 ...

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

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

  6. Python NumPy学习总结

    一.NumPy简介 其官网是:http://www.numpy.org/ NumPy是Python语言的一个扩充程序库.支持高级大量的维度数组与矩阵运算,此外也针对数组运算提供大量的数学函数库.Num ...

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

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

  8. numpy 学习笔记

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

  9. NumPy 从已有的数组创建数组

    NumPy 从已有的数组创建数组 本章节我们将学习如何从已有的数组创建数组. numpy.asarray numpy.asarray 类似 numpy.array,但 numpy.asarray 只有 ...

随机推荐

  1. nginx添加编译lua模块

    一 .安装LuaJit 1.下载LuaJit # wget http://luajit.org/download/LuaJIT-2.0.5.tar.gz 2.编译安装 # tar xzvf LuaJI ...

  2. The POM for * is invalid

    The POM for yanan:jar:1.0-SNAPSHOT is invalid, transitive dependencies (if any) will not be availabl ...

  3. 自己写的日志框架--linkinLog4j--框架可配置+提性能

    OK,上一篇博客我们已经实现了日志框架的基本的功能,但是还有一个最大的问题就是日志输出地不能重定向,然后一些输出也不可控.那现在我们来实现一个比较完整的日志框架. 设计思路如下: 1,定义一堆常量Li ...

  4. rem与@media 的优缺点

    首先:   如果我们在做单独移动端网站或者app的时候  我建议  使用 rem  ; 他能让我们在手机各个机型的适配方面:大大减少我们代码的重复性,是我们的代码更兼容. 下面两个图一个调试在常用的机 ...

  5. jsp中 scope="application" 表示

    jsp中 <jsp:useBean id="countbean" scope="application" class="count.counte ...

  6. 八大排序算法Java实现

    本文对常见的排序算法进行了总结. 常见排序算法如下: 直接插入排序 希尔排序 简单选择排序 堆排序 冒泡排序 快速排序 归并排序 基数排序 它们都属于内部排序,也就是只考虑数据量较小仅需要使用内存的排 ...

  7. 洛谷 [P1265] 公路修建

    本题的描述:城市联盟,最短距离.. 使人想到了prim求MST,再一看数据范围:完全图!,那么一定得用prim,因为只有5000个点,所以不加优化的prim就能过. #include <iost ...

  8. ZOJ 2314 Reactor Cooling [无源汇上下界网络流]

    贴个板子 #include <iostream> #include <cstdio> #include <cstring> #include <algorit ...

  9. Python之MYsql、数据库

    一.数据库的操作及安装 1.安装  MySQL Community Server 5.7.16   ----   版本 2.初始化   mysqld --inisialize-insecure 3.启 ...

  10. 有关static静态方法知识的收集

    1.何时使用静态方法: 如果某些操作不依赖具体实例,那它就是静态的,反之如果某些操作是依赖具体实例的(例如访问一个特定会员的名称),那它就应该是实例化的. 2.静态方法和实例方法的区别主要体现在两个方 ...