NumPy百题精解:从入门到进阶的100个实战练习
2026-02-04 04:21:39作者:牧宁李
还在为NumPy学习找不到系统练习而烦恼?本文提供100个精心设计的NumPy练习题,涵盖从基础操作到高级应用的各个层面,每个题目都配有详细解答和实用技巧,助你快速掌握NumPy核心技能!
📋 你将获得
- 系统学习路径:从基础到高级的完整练习体系
- 实战代码示例:每个题目都提供可运行的代码解决方案
- 技巧与提示:关键函数的用法提示和最佳实践
- 问题分类:按难度星级(★☆☆到★★★)分级,适合不同水平学习者
- 常见陷阱:避免NumPy使用中的常见错误
🎯 练习难度分级
| 难度 | 题目数量 | 适合人群 |
|---|---|---|
| ★☆☆ | 37题 | 初学者,基础操作 |
| ★★☆ | 31题 | 进阶用户,数据处理 |
| ★★★ | 32题 | 高级应用,性能优化 |
🚀 基础入门练习(★☆☆)
1. 导入NumPy包
import numpy as np
2. 打印NumPy版本和配置信息
print(np.__version__)
np.show_config()
3. 创建大小为10的空向量
Z = np.zeros(10)
print(Z)
4. 查找任意数组的内存大小
Z = np.zeros((10,10))
print("%d bytes" % (Z.size * Z.itemsize))
5. 从命令行获取NumPy add函数的文档
# 在命令行中执行
python -c "import numpy; numpy.info(numpy.add)"
6. 创建大小为10的空向量,但第五个值为1
Z = np.zeros(10)
Z[4] = 1
print(Z)
7. 创建值范围从10到49的向量
Z = np.arange(10,50)
print(Z)
8. 反转向量(第一个元素变为最后一个)
Z = np.arange(50)
Z = Z[::-1]
print(Z)
9. 创建3x3矩阵,值范围从0到8
Z = np.arange(9).reshape(3, 3)
print(Z)
10. 从[1,2,0,0,4,0]中查找非零元素的索引
nz = np.nonzero([1,2,0,0,4,0])
print(nz)
📊 进阶数据处理练习(★★☆)
44. 将笛卡尔坐标转换为极坐标
Z = np.random.random((10,2))
X, Y = Z[:,0], Z[:,1]
R = np.sqrt(X**2 + Y**2) # 半径
T = np.arctan2(Y, X) # 角度
print(R)
print(T)
45. 创建随机向量并替换最大值为0
Z = np.random.random(10)
Z[Z.argmax()] = 0
print(Z)
46. 创建覆盖[0,1]x[0,1]区域的结构化数组
Z = np.zeros((5,5), [('x',float),('y',float)])
Z['x'], Z['y'] = np.meshgrid(np.linspace(0,1,5),
np.linspace(0,1,5))
print(Z)
47. 构建柯西矩阵(Cauchy Matrix)
X = np.arange(8)
Y = X + 0.5
C = 1.0 / np.subtract.outer(X, Y) # Cij = 1/(xi - yj)
print(np.linalg.det(C))
48. 打印每种NumPy标量类型的最小和最大可表示值
for dtype in [np.int8, np.int32, np.int64]:
print(np.iinfo(dtype).min)
print(np.iinfo(dtype).max)
for dtype in [np.float32, np.float64]:
print(np.finfo(dtype).min)
print(np.finfo(dtype).max)
print(np.finfo(dtype).eps) # 机器精度
🧠 高级应用练习(★★★)
75. 使用滑动窗口计算平均值
def moving_average(a, n=3):
ret = np.cumsum(a, dtype=float)
ret[n:] = ret[n:] - ret[:-n]
return ret[n - 1:] / n
Z = np.arange(20)
print(moving_average(Z, n=3))
# NumPy 1.20+ 更简洁的解决方案
from numpy.lib.stride_tricks import sliding_window_view
print(sliding_window_view(Z, window_shape=3).mean(axis=-1))
76. 构建滑动窗口数组
from numpy.lib import stride_tricks
def rolling(a, window):
shape = (a.size - window + 1, window)
strides = (a.strides[0], a.strides[0])
return stride_tricks.as_strided(a, shape=shape, strides=strides)
Z = rolling(np.arange(10), 3)
print(Z)
88. 使用NumPy数组实现生命游戏(Game of Life)
def iterate(Z):
# 计算邻居数量
N = (Z[0:-2,0:-2] + Z[0:-2,1:-1] + Z[0:-2,2:] +
Z[1:-1,0:-2] + Z[1:-1,2:] +
Z[2: ,0:-2] + Z[2: ,1:-1] + Z[2: ,2:])
# 应用规则
birth = (N==3) & (Z[1:-1,1:-1]==0) # 出生条件
survive = ((N==2) | (N==3)) & (Z[1:-1,1:-1]==1) # 生存条件
Z[...] = 0
Z[1:-1,1:-1][birth | survive] = 1
return Z
Z = np.random.randint(0,2,(50,50))
for i in range(100): Z = iterate(Z)
print(Z)
92. 三种方法计算大向量的三次方
x = np.random.rand(int(5e7))
# 方法1:使用np.power
%timeit np.power(x,3)
# 方法2:直接乘法(最快)
%timeit x*x*x
# 方法3:使用einsum
%timeit np.einsum('i,i,i->i',x,x,x)
100. 计算自助法(Bootstrap)95%置信区间
X = np.random.randn(100) # 随机1D数组
N = 1000 # 自助样本数量
idx = np.random.randint(0, X.size, (N, X.size))
means = X[idx].mean(axis=1)
confint = np.percentile(means, [2.5, 97.5]) # 95%置信区间
print(confint)
📈 NumPy性能优化技巧
使用向量化操作替代循环
# 慢:使用循环
result = np.zeros(1000)
for i in range(1000):
result[i] = i * 2
# 快:向量化操作
result = np.arange(1000) * 2
利用广播(Broadcasting)机制
# 传统方法
A = np.ones((5,3))
B = np.ones((3,2))
result = np.zeros((5,2))
for i in range(5):
for j in range(2):
for k in range(3):
result[i,j] += A[i,k] * B[k,j]
# 广播方法
result = A @ B # 矩阵乘法
内存视图优化
# 创建视图而非副本
Z = np.arange(10)
Z_view = Z[::2] # 视图,不复制数据
Z_copy = Z[::2].copy() # 副本,复制数据
🎓 学习路线建议
graph TD
A[NumPy基础] --> B[数组创建与操作]
A --> C[索引与切片]
A --> D[数据类型]
B --> E[进阶数据处理]
C --> E
D --> E
E --> F[线性代数运算]
E --> G[随机数生成]
E --> H[文件IO操作]
F --> I[高级应用]
G --> I
H --> I
I --> J[性能优化]
I --> K[实际项目应用]
📋 完整题目列表
| 题号 | 题目描述 | 难度 | 关键函数 |
|---|---|---|---|
| 1-10 | 基础导入和数组创建 | ★☆☆ | zeros, arange, eye |
| 11-20 | 矩阵操作和索引 | ★☆☆ | reshape, nonzero, diag |
| 21-30 | 数学运算和比较 | ★☆☆ | random, mean, intersect1d |
| 31-40 | 高级数组操作 | ★★☆ | seterr, datetime64, fromiter |
| 41-50 | 数据分析和处理 | ★★☆ | allclose, argmax, genfromtxt |
| 51-60 | 结构化数组 | ★★☆ | dtype, meshgrid, argsort |
| 61-70 | 性能优化技巧 | ★★★ | bincount, einsum, stride_tricks |
| 71-80 | 高级数学应用 | ★★★ | tensordot, linalg.svd, unique |
| 81-90 | 实际项目案例 | ★★★ | sliding_window_view, game of life |
| 91-100 | 统计和机器学习 | ★★★ | percentile, bootstrap, confidence intervals |
💡 学习建议
- 循序渐进:从★☆☆难度开始,逐步挑战更高难度题目
- 动手实践:每个题目都亲自编写代码运行
- 理解原理:不仅记住答案,更要理解为什么这样解决
- 举一反三:尝试用不同方法解决同一问题
- 项目应用:将学到的技巧应用到实际数据分析项目中
🎯 下一步学习方向
完成这100个练习后,你可以进一步学习:
- Pandas:用于数据清洗和分析
- Matplotlib/Seaborn:数据可视化
- Scikit-learn:机器学习算法
- SciPy:科学计算扩展库
- 深度学习框架:TensorFlow/PyTorch
通过这100个精心设计的NumPy练习,你将从入门到精通,掌握数据处理的核心技能,为后续的数据科学和机器学习学习打下坚实基础!
登录后查看全文
热门项目推荐
相关项目推荐
Kimi-K2.5Kimi K2.5 是一款开源的原生多模态智能体模型,它在 Kimi-K2-Base 的基础上,通过对约 15 万亿混合视觉和文本 tokens 进行持续预训练构建而成。该模型将视觉与语言理解、高级智能体能力、即时模式与思考模式,以及对话式与智能体范式无缝融合。Python00- QQwen3-Coder-Next2026年2月4日,正式发布的Qwen3-Coder-Next,一款专为编码智能体和本地开发场景设计的开源语言模型。Python00
xw-cli实现国产算力大模型零门槛部署,一键跑通 Qwen、GLM-4.7、Minimax-2.1、DeepSeek-OCR 等模型Go06
PaddleOCR-VL-1.5PaddleOCR-VL-1.5 是 PaddleOCR-VL 的新一代进阶模型,在 OmniDocBench v1.5 上实现了 94.5% 的全新 state-of-the-art 准确率。 为了严格评估模型在真实物理畸变下的鲁棒性——包括扫描伪影、倾斜、扭曲、屏幕拍摄和光照变化——我们提出了 Real5-OmniDocBench 基准测试集。实验结果表明,该增强模型在新构建的基准测试集上达到了 SOTA 性能。此外,我们通过整合印章识别和文本检测识别(text spotting)任务扩展了模型的能力,同时保持 0.9B 的超紧凑 VLM 规模,具备高效率特性。Python00
KuiklyUI基于KMP技术的高性能、全平台开发框架,具备统一代码库、极致易用性和动态灵活性。 Provide a high-performance, full-platform development framework with unified codebase, ultimate ease of use, and dynamic flexibility. 注意:本仓库为Github仓库镜像,PR或Issue请移步至Github发起,感谢支持!Kotlin08
VLOOKVLOOK™ 是优雅好用的 Typora/Markdown 主题包和增强插件。 VLOOK™ is an elegant and practical THEME PACKAGE × ENHANCEMENT PLUGIN for Typora/Markdown.Less00
热门内容推荐
最新内容推荐
5分钟掌握ImageSharp色彩矩阵变换:图像色调调整的终极指南3分钟解决Cursor试用限制:go-cursor-help工具全攻略Transmission数据库迁移工具:转移种子状态到新设备如何在VMware上安装macOS?解锁神器Unlocker完整使用指南如何为so-vits-svc项目贡献代码:从提交Issue到创建PR的完整指南Label Studio数据处理管道设计:ETL流程与标注前预处理终极指南突破拖拽限制:React Draggable社区扩展与实战指南如何快速安装 JSON Formatter:让 JSON 数据阅读更轻松的终极指南Element UI表格数据地图:Table地理数据可视化如何快速去除视频水印?免费开源神器「Video Watermark Remover」一键搞定!
项目优选
收起
deepin linux kernel
C
27
11
OpenHarmony documentation | OpenHarmony开发者文档
Dockerfile
527
3.73 K
Ascend Extension for PyTorch
Python
336
400
暂无简介
Dart
768
191
本项目是CANN提供的数学类基础计算算子库,实现网络在NPU上加速计算。
C++
882
589
openEuler内核是openEuler操作系统的核心,既是系统性能与稳定性的基石,也是连接处理器、设备与服务的桥梁。
C
336
170
React Native鸿蒙化仓库
JavaScript
302
353
Nop Platform 2.0是基于可逆计算理论实现的采用面向语言编程范式的新一代低代码开发平台,包含基于全新原理从零开始研发的GraphQL引擎、ORM引擎、工作流引擎、报表引擎、规则引擎、批处理引引擎等完整设计。nop-entropy是它的后端部分,采用java语言实现,可选择集成Spring框架或者Quarkus框架。中小企业可以免费商用
Java
12
1
🎉 (RuoYi)官方仓库 基于SpringBoot,Spring Security,JWT,Vue3 & Vite、Element Plus 的前后端分离权限管理系统
Vue
1.33 K
749
openJiuwen agent-studio提供零码、低码可视化开发和工作流编排,模型、知识库、插件等各资源管理能力
TSX
986
246