本文将为您提供关于Numpy的结构化数组的详细介绍,我们还将为您解释numpy的结构化数组头歌的相关知识,同时,我们还将为您提供关于"importnumpyasnp"ImportError:Nomod
本文将为您提供关于Numpy 的结构化数组的详细介绍,我们还将为您解释numpy的结构化数组头歌的相关知识,同时,我们还将为您提供关于"import numpy as np" ImportError: No module named numpy、3.7Python 数据处理篇之 Numpy 系列 (七)---Numpy 的统计函数、Anaconda Numpy 错误“Importing the Numpy C Extension Failed”是否有另一种解决方案、cvxpy 和 numpy 之间的版本冲突:“针对 API 版本 0xe 编译的模块,但此版本的 numpy 是 0xd”的实用信息。
本文目录一览:- Numpy 的结构化数组(numpy的结构化数组头歌)
- "import numpy as np" ImportError: No module named numpy
- 3.7Python 数据处理篇之 Numpy 系列 (七)---Numpy 的统计函数
- Anaconda Numpy 错误“Importing the Numpy C Extension Failed”是否有另一种解决方案
- cvxpy 和 numpy 之间的版本冲突:“针对 API 版本 0xe 编译的模块,但此版本的 numpy 是 0xd”
Numpy 的结构化数组(numpy的结构化数组头歌)
1. 场景示例:
假定现在有关于一些人的分类数据(如 姓名,年龄和体重),我们需要存储这些数据用于 Python 项目,那么一种可行的方法是将他们存在三个单独的数组中:
name = [''Alice'',''Bob'',''Cathy'',''Doug'']
age = [25,45,37,19]
weight = [55.0, 85.5, 68.0, 61.5]
如果可以用单一的结构来存储所有的数据,那么看起来会更自然,Numpy 可以用结构化数组来实现这种存储,这些结构化数组是复合数据类型。
import numpy as np
# 通过指定复合数据类型,可以构造一个结构化数组
data = np.zeros(4,dtype={
''names'':(''name'',''age'',''weight''),
''formats'':(''U10'',''i4'',''f8'') # 这里的 ''U0'' 表示“长度不超过10的Unicode字符串”,''i4'' 表示“4字节(即32比特)整型”,''f8'' 表示“8字节(即64比特)浮点型”
})
print("1. data.dtype: ",data.dtype)
data[''name''] = name
data[''age''] = age
data[''weight''] = weight
print("2. data: ",data)
# 结构化数组的方便之处在于,可以通过索引或者名称查看相应的值
print("3. 获取所有的名字:",data[''name''])
print("4. 获取数据第一行:",data[0])
print("5. 获取数据的最后一行的名字:",data[-1][''name''])
print("6. 获取年龄小于30岁的人的名字:",data[data[''age''] < 30][''name''])
print 输出如下:
1. data.dtype: [(''name'', ''<U10''), (''age'', ''<i4''), (''weight'', ''<f8'')]
# 正如我们希望的,所有的数据被安排在一个内存块中
2. data: [(''Alice'', 25, 55. ) (''Bob'', 45, 85.5) (''Cathy'', 37, 68. )
(''Doug'', 19, 61.5)]
3. 获取所有的名字: [''Alice'' ''Bob'' ''Cathy'' ''Doug'']
4. 获取数据第一行: (''Alice'', 25, 55.)
5. 获取数据的最后一行的名字: Doug
6. 获取年龄小于30岁的人的名字: [''Alice'' ''Doug'']
2. 生成结构化数组
结构化数组的数据类型有多种制定方式:
# 1. 采用字典的方法:
np.dtype({''names'':(''name'', ''age'', ''weight''),
''formats'':(''U10'', ''i4'', ''f8'')})
dtype([(''name'', ''<U10''), (''age'', ''<i4''), (''weight'', ''<f8'')])
# 2. 数值数据类型可以用Python类型和Numpy的dtype类型指定:
np.dtype({''names'':(''name'', ''age'', ''weight''),
''formats'':((np.str_, 10), int, np.float32)})
dtype([(''name'', ''<U10''), (''age'', ''<i8''), (''weight'', ''<f4'')])
# 3. 使用元组的方式:
np.dtype([(''name'', ''S10''), (''age'', ''i4''), (''weight'', ''f8'')])
dtype([(''name'', ''S10''), (''age'', ''<i4''), (''weight'', ''<f8'')])
如果类型的名称对你来说并不重要,那你可以仅仅用一个字符串来指定它,在该字符串中数据类型用逗号分隔:
np.dtype(''S10,i4,f8'')
dtype([(''f0'', ''S10''), (''f1'', ''<i4''), (''f2'', ''<f8'')])
简写的字符串格式的代码可能看起来令人困惑,但是它们其实基于非常简单的规则。第一个(可选)字符是 <或者>,分别表示 “低字节序 "和" 高字节序 ",表示字节(bytes)类型的数据在内存中存放顺序的习惯用法,后一个字符指定的数据类型的类型:字符、字节、整形、浮点型,等等。最后一个字符表示该对象的字节大小。
Numpy 的数据类型
字符 | 描述 | 举例 |
---|---|---|
''b'' |
Byte | np.dtype(''b'') |
''i'' |
Signed integer | np.dtype(''i4'') == np.int32 |
''u'' |
Unsigned integer | np.dtype(''u1'') == np.uint8 |
''f'' |
Floating point | np.dtype(''f8'') == np.int64 |
''c'' |
Complex floating point | np.dtype(''c16'') == np.complex128 |
''S'' , ''a'' |
String | np.dtype(''S5'') |
''U'' |
Unicode string | np.dtype(''U'') == np.str_ |
''V'' |
Raw data (void) | np.dtype(''V'') == np.void |
3. 更高级的复合类型
Numpy 中也可以定义更高级的复合数据类型,例如:你可以创建一种类型,其中每个元素都包含一个数组或矩阵。
# 数据类型用mat组件包含一个3 x 3的浮点型矩阵
tp = np.dtype([(''id'', ''i8''), (''mat'', ''f8'', (3, 3))])
X = np.zeros(1, dtype=tp)
print(X[0])
print(X[''mat''][0])
(0, [[0.0, 0.0, 0.0], [0.0, 0.0, 0.0], [0.0, 0.0, 0.0]])
[[ 0. 0. 0.]
[ 0. 0. 0.]
[ 0. 0. 0.]]
4. 记录数组
Numpy 还提供了 np.recarray 类。它和前面介绍的结构化数组几乎相同,但是它有一个独特的特征:域可以像属性一样获取,而不是像字典的键那样获取
# 前面的例子通过以下代码获取年龄:
data[''age'']
array([25, 45, 37, 19], dtype=int32)
如果将这些数据当作一个记录数组,采用很少的按键来获取这个结果:
data_rec = data.view(np.recarray)
data_rec.age
array([25, 45, 37, 19], dtype=int32)
记录数组的不好的地方在于,即使使用相同的语法,在获取域时也会有一些额外的开销:
%timeit data[''age''] # 1
%timeit data_rec[''age''] # 2
%timeit data_rec.age # 3
从输出结果中可以看出,第 3 行 比第 2 行 代码执行花费的时间要多一点点
274 ns ± 133 ns per loop (mean ± std. dev. of 7 runs, 1000000 loops each)
4.39 µs ± 1.17 µs per loop (mean ± std. dev. of 7 runs, 100000 loops each)
5.17 µs ± 368 ns per loop (mean ± std. dev. of 7 runs, 100000 loops each)
"import numpy as np" ImportError: No module named numpy
问题:没有安装 numpy
解决方法:
下载文件,安装
numpy-1.8.2-win32-superpack-python2.7
安装运行 import numpy,出现
Traceback (most recent call last):
File "<pyshell#2>", line 1, in <module>
import numpy
File "C:\Python27\lib\site-packages\numpy\__init__.py", line 153, in <module>
from . import add_newdocs
File "C:\Python27\lib\site-packages\numpy\add_newdocs.py", line 13, in <module>
from numpy.lib import add_newdoc
File "C:\Python27\lib\site-packages\numpy\lib\__init__.py", line 8, in <module>
from .type_check import *
File "C:\Python27\lib\site-packages\numpy\lib\type_check.py", line 11, in <module>
import numpy.core.numeric as _nx
File "C:\Python27\lib\site-packages\numpy\core\__init__.py", line 6, in <module>
from . import multiarray
ImportError: DLL load failed: %1 不是有效的 Win32 应用程序。
原因是:python 装的是 64 位的,numpy 装的是 32 位的
重新安装 numpy 为:numpy-1.8.0-win64-py2.7
3.7Python 数据处理篇之 Numpy 系列 (七)---Numpy 的统计函数
目录
[TOC]
前言
具体我们来学 Numpy 的统计函数
(一)函数一览表
调用方式:np.*
.sum(a) | 对数组 a 求和 |
---|---|
.mean(a) | 求数学期望 |
.average(a) | 求平均值 |
.std(a) | 求标准差 |
.var(a) | 求方差 |
.ptp(a) | 求极差 |
.median(a) | 求中值,即中位数 |
.min(a) | 求最大值 |
.max(a) | 求最小值 |
.argmin(a) | 求最小值的下标,都处里为一维的下标 |
.argmax(a) | 求最大值的下标,都处里为一维的下标 |
.unravel_index(index, shape) | g 根据 shape, 由一维的下标生成多维的下标 |
(二)统计函数 1
(1)说明
(2)输出
.sum(a)
.mean(a)
.average(a)
.std(a)
.var(a)
(三)统计函数 2
(1)说明
(2)输出
.max(a) .min(a)
.ptp(a)
.median(a)
.argmin(a)
.argmax(a)
.unravel_index(index,shape)
作者:Mark
日期:2019/02/11 周一
Anaconda Numpy 错误“Importing the Numpy C Extension Failed”是否有另一种解决方案
如何解决Anaconda Numpy 错误“Importing the Numpy C Extension Failed”是否有另一种解决方案?
希望有人能在这里提供帮助。我一直在绕圈子一段时间。我只是想设置一个 python 脚本,它将一些 json 数据从 REST API 加载到云数据库中。我在 Anaconda 上设置了一个虚拟环境(因为 GCP 库推荐这样做),安装了依赖项,现在我只是尝试导入库并向端点发送请求。 我使用 Conda(和 conda-forge)来设置环境并安装依赖项,所以希望一切都干净。我正在使用带有 Python 扩展的 VS 编辑器作为编辑器。 每当我尝试运行脚本时,我都会收到以下消息。我已经尝试了其他人在 Google/StackOverflow 上找到的所有解决方案,但没有一个有效。我通常使用 IDLE 或 Jupyter 进行脚本编写,没有任何问题,但我对 Anaconda、VS 或环境变量(似乎是相关的)没有太多经验。 在此先感谢您的帮助!
\Traceback (most recent call last):
File "C:\Conda\envs\gcp\lib\site-packages\numpy\core\__init__.py",line 22,in <module>
from . import multiarray
File "C:\Conda\envs\gcp\lib\site-packages\numpy\core\multiarray.py",line 12,in <module>
from . import overrides
File "C:\Conda\envs\gcp\lib\site-packages\numpy\core\overrides.py",line 7,in <module>
from numpy.core._multiarray_umath import (
ImportError: DLL load Failed while importing _multiarray_umath: The specified module Could not be found.
During handling of the above exception,another exception occurred:
Traceback (most recent call last):
File "c:\API\citi-bike.py",line 4,in <module>
import numpy as np
File "C:\Conda\envs\gcp\lib\site-packages\numpy\__init__.py",line 150,in <module>
from . import core
File "C:\Conda\envs\gcp\lib\site-packages\numpy\core\__init__.py",line 48,in <module>
raise ImportError(msg)
ImportError:
IMPORTANT: PLEASE READ THIS FOR ADVICE ON HOW TO SOLVE THIS ISSUE!
Importing the numpy C-extensions Failed. This error can happen for
many reasons,often due to issues with your setup or how NumPy was
installed.
We have compiled some common reasons and troubleshooting tips at:
https://numpy.org/devdocs/user/troubleshooting-importerror.html
Please note and check the following:
* The Python version is: python3.9 from "C:\Conda\envs\gcp\python.exe"
* The NumPy version is: "1.21.1"
and make sure that they are the versions you expect.
Please carefully study the documentation linked above for further help.
Original error was: DLL load Failed while importing _multiarray_umath: The specified module Could not be found.
解决方法
暂无找到可以解决该程序问题的有效方法,小编努力寻找整理中!
如果你已经找到好的解决方法,欢迎将解决方案带上本链接一起发送给小编。
小编邮箱:dio#foxmail.com (将#修改为@)
cvxpy 和 numpy 之间的版本冲突:“针对 API 版本 0xe 编译的模块,但此版本的 numpy 是 0xd”
如何解决cvxpy 和 numpy 之间的版本冲突:“针对 API 版本 0xe 编译的模块,但此版本的 numpy 是 0xd”?
我正在尝试升级一些软件包并为现有的 Python 程序整合我的 requirements.txt
,以便将其移至 docker 容器。
这个容器将基于 tensorflow docker 容器,这决定了我必须使用的一些包版本。我们在 windows 下工作,我们希望能够在我们的机器上本地运行该程序(至少在一段时间内)。所以我需要找到一个适用于 docker 和 Windows 10 的配置。
Tensorflow 2.4.1
需要 numpy~=1.19.2
。使用 numpy 1.20
时,pip
会抱怨 numpy 1.20
是一个不兼容的版本。
但是在使用 numpy~=1.19.2
时,导入 cvxpy
时出现以下错误。 pip
安装所有软件包都很好:
RuntimeError: module compiled against API version 0xe but this version of numpy is 0xd
Traceback (most recent call last):
File "test.py",line 1,in <module>
import cvxpy
File "c:\Projekte\algo5\venv\lib\site-packages\cvxpy\__init__.py",line 18,in <module>
from cvxpy.atoms import *
File "c:\Projekte\algo5\venv\lib\site-packages\cvxpy\atoms\__init__.py",line 20,in <module>
from cvxpy.atoms.geo_mean import geo_mean
File "c:\Projekte\algo5\venv\lib\site-packages\cvxpy\atoms\geo_mean.py",in <module>
from cvxpy.utilities.power_tools import (fracify,decompose,approx_error,lower_bound,File "c:\Projekte\algo5\venv\lib\site-packages\cvxpy\utilities\power_tools.py",in <module>
from cvxpy.atoms.affine.reshape import reshape
File "c:\Projekte\algo5\venv\lib\site-packages\cvxpy\atoms\affine\reshape.py",in <module>
from cvxpy.atoms.affine.hstack import hstack
File "c:\Projekte\algo5\venv\lib\site-packages\cvxpy\atoms\affine\hstack.py",in <module>
from cvxpy.atoms.affine.affine_atom import AffAtom
File "c:\Projekte\algo5\venv\lib\site-packages\cvxpy\atoms\affine\affine_atom.py",line 22,in <module>
from cvxpy.cvxcore.python import canonInterface
File "c:\Projekte\algo5\venv\lib\site-packages\cvxpy\cvxcore\python\__init__.py",line 3,in <module>
import _cvxcore
ImportError: numpy.core.multiarray Failed to import
重现步骤:
1.)
在 Windows 10 下创建一个新的 Python 3.8 venv
并激活它
2.) 通过 requirements.txt
安装以下 pip install -r requirements.txt
:
cvxpy
numpy~=1.19.2 # tensorflow 2.4.1 requires this version
3.) 通过 test.py
python test.py
import cvxpy
if __name__ == ''__main__'':
pass
如果我想使用 tensorflow 2.3
,也会发生同样的事情。在这种情况下需要 numpy~=1.18
,错误完全相同。
搜索错误发现很少的命中,可悲的是没有帮助我。
我该怎么做才能解决这个问题?
解决方法
暂无找到可以解决该程序问题的有效方法,小编努力寻找整理中!
如果你已经找到好的解决方法,欢迎将解决方案带上本链接一起发送给小编。
小编邮箱:dio#foxmail.com (将#修改为@)
今天关于Numpy 的结构化数组和numpy的结构化数组头歌的讲解已经结束,谢谢您的阅读,如果想了解更多关于"import numpy as np" ImportError: No module named numpy、3.7Python 数据处理篇之 Numpy 系列 (七)---Numpy 的统计函数、Anaconda Numpy 错误“Importing the Numpy C Extension Failed”是否有另一种解决方案、cvxpy 和 numpy 之间的版本冲突:“针对 API 版本 0xe 编译的模块,但此版本的 numpy 是 0xd”的相关知识,请在本站搜索。
本文标签: