Python数据科学:Numpy库一些简单区分

简介: Python数据科学:Numpy库一些简单区分

image.png

image.png

# -*- coding: utf-8 -*-
# @File    : base_use.py
# @Date    : 2018-07-25
# @Author  : Peng Shiyu
import numpy as np
# 一维数组
animals = np.array(["pig", "dog", "cat"])
print(type(animals), animals)
# <class 'numpy.ndarray'> ['pig' 'dog' 'cat']
print(animals[1])  # dog
# 二维数组
X = np.array([[1, 2, 3], [4, 5, 6], [7, 8, 9]])
print(type(X), X)
# <class 'numpy.ndarray'>
# [[1 2 3]
#  [4 5 6]
#  [7 8 9]]
print(X[1][1])  # 5
X = np.array(range(6)).reshape(2, 3)
print(X)
"""
[[0 1 2]
 [3 4 5]]
"""
# 三维数组
X = np.arange(24).reshape(2, 3, 4)
print(X)
"""
[[[ 0  1  2  3]
  [ 4  5  6  7]
  [ 8  9 10 11]]
 [[12 13 14 15]
  [16 17 18 19]
  [20 21 22 23]]]
"""
# 维度
print(X.ndim)
# 3
# 形状
print(X.shape)
# (2, 3, 4)  z, y, x
#  x, y, z 对应的shape元组是从右往左数的
# 打开图片(540 * 258) 长 * 宽
from matplotlib.pylab import plt
image = plt.imread("images/baidu.png")
print(image.shape)
# (258, 540, 4)
# (y, x, c)
# axis 0, axis 1, axis 2
# 抽象座标轴顺序从左向右。指定哪个轴,就只在哪个轴向操作,其他轴不受影响。
# 排序
data = np.arange(12)
np.random.shuffle(data)
data = data.reshape(3, 4)
print(data)
"""
[[ 2  5  7  8]
 [ 4  0 10  3]
 [ 1 11  6  9]]
"""
data = np.array([
    [2, 5, 7, 8],
    [4, 0, 10, 3],
    [1, 11, 6, 9],
])
print(np.sort(data, axis=0))
"""
[[ 1  0  6  3]
 [ 2  5  7  8]
 [ 4 11 10  9]]
"""
print(np.sort(data, axis=1))
"""
[[ 2  5  7  8]
 [ 0  3  4 10]
 [ 1  6  9 11]]
"""
"""
理解轴:
shape:  (3, 4)
axis:    0, 1
AXIS:    y, x
"""
# 求和、均值、方差、最大、最小、累加、累乘
# sum,mean,std,var,min,max 会导致这个轴被压扁,缩减为一个数值
data = np.arange(24).reshape(2, 3, 4)
print(data)
"""
[[[ 0  1  2  3]
  [ 4  5  6  7]
  [ 8  9 10 11]]
 [[12 13 14 15]
  [16 17 18 19]
  [20 21 22 23]]]
"""
print(np.sum(data, axis=0))
print(np.sum(data, axis=1))
print(np.sum(data, axis=2))
"""
[[12 14 16 18]
 [20 22 24 26]
 [28 30 32 34]]
[[12 15 18 21]
 [48 51 54 57]]
[[ 6 22 38]
 [54 70 86]]
"""
# 切片和索引
# 在索引中出现冒号(:),则本轴继续存在,如果只是一个数值,则本轴消失
data = np.arange(24).reshape(2, 3, 4)
print(data)
"""
[[[ 0  1  2  3]
  [ 4  5  6  7]
  [ 8  9 10 11]]
 [[12 13 14 15]
  [16 17 18 19]
  [20 21 22 23]]]
"""
print(data[0, :, :])
"""
[[ 0  1  2  3]
 [ 4  5  6  7]
 [ 8  9 10 11]]
"""
print(data[0, 1, 2])
# 6
print(data[0:1, 1:2, 2:3])
# [[[6]]]   有三个 [,那么就是三维数组
#  拼接(concatenating)
data = np.arange(4).reshape(2, 2)
print(data)
"""
[[0 1]
 [2 3]]
"""
print(np.concatenate([data, data], axis=0))
print(np.concatenate([data, data], axis=1))
"""
[[0 1]
 [2 3]
 [0 1]
 [2 3]]
[[0 1 0 1]
 [2 3 2 3]]
"""
# reshape
# ndarray 的数据在内存里以一维线性存放,
# reshape 前后,数据没有变化,只是访问方式变了而已。
相关文章
|
2月前
|
存储 Java 数据处理
(numpy)Python做数据处理必备框架!(一):认识numpy;从概念层面开始学习ndarray数组:形状、数组转置、数值范围、矩阵...
Numpy是什么? numpy是Python中科学计算的基础包。 它是一个Python库,提供多维数组对象、各种派生对象(例如掩码数组和矩阵)以及用于对数组进行快速操作的各种方法,包括数学、逻辑、形状操作、排序、选择、I/0 、离散傅里叶变换、基本线性代数、基本统计运算、随机模拟等等。 Numpy能做什么? numpy的部分功能如下: ndarray,一个具有矢量算术运算和复杂广播能力的快速且节省空间的多维数组 用于对整组数据进行快速运算的标准数学函数(无需编写循环)。 用于读写磁盘数据的工具以及用于操作内存映射文件的工具。 线性代数、随机数生成以及傅里叶变换功能。 用于集成由C、C++
313 1
|
2月前
|
Java 数据处理 索引
(numpy)Python做数据处理必备框架!(二):ndarray切片的使用与运算;常见的ndarray函数:平方根、正余弦、自然对数、指数、幂等运算;统计函数:方差、均值、极差;比较函数...
ndarray切片 索引从0开始 索引/切片类型 描述/用法 基本索引 通过整数索引直接访问元素。 行/列切片 使用冒号:切片语法选择行或列的子集 连续切片 从起始索引到结束索引按步长切片 使用slice函数 通过slice(start,stop,strp)定义切片规则 布尔索引 通过布尔条件筛选满足条件的元素。支持逻辑运算符 &、|。
163 0
|
3月前
|
存储 人工智能 测试技术
如何使用LangChain的Python库结合DeepSeek进行多轮次对话?
本文介绍如何使用LangChain结合DeepSeek实现多轮对话,测开人员可借此自动生成测试用例,提升自动化测试效率。
460 125
如何使用LangChain的Python库结合DeepSeek进行多轮次对话?
|
3月前
|
监控 数据可视化 数据挖掘
Python Rich库使用指南:打造更美观的命令行应用
Rich库是Python的终端美化利器,支持彩色文本、智能表格、动态进度条和语法高亮,大幅提升命令行应用的可视化效果与用户体验。
222 0
|
2月前
|
数据可视化 关系型数据库 MySQL
【可视化大屏】全流程讲解用python的pyecharts库实现拖拽可视化大屏的背后原理,简单粗暴!
本文详解基于Python的电影TOP250数据可视化大屏开发全流程,涵盖爬虫、数据存储、分析及可视化。使用requests+BeautifulSoup爬取数据,pandas存入MySQL,pyecharts实现柱状图、饼图、词云图、散点图等多种图表,并通过Page组件拖拽布局组合成大屏,支持多种主题切换,附完整源码与视频讲解。
234 4
【可视化大屏】全流程讲解用python的pyecharts库实现拖拽可视化大屏的背后原理,简单粗暴!
|
2月前
|
传感器 运维 前端开发
Python离群值检测实战:使用distfit库实现基于分布拟合的异常检测
本文解析异常(anomaly)与新颖性(novelty)检测的本质差异,结合distfit库演示基于概率密度拟合的单变量无监督异常检测方法,涵盖全局、上下文与集体离群值识别,助力构建高可解释性模型。
309 10
Python离群值检测实战:使用distfit库实现基于分布拟合的异常检测
|
4月前
|
运维 Linux 开发者
Linux系统中使用Python的ping3库进行网络连通性测试
以上步骤展示了如何利用 Python 的 `ping3` 库来检测网络连通性,并且提供了基本错误处理方法以确保程序能够优雅地处理各种意外情形。通过简洁明快、易读易懂、实操性强等特点使得该方法非常适合开发者或系统管理员快速集成至自动化工具链之内进行日常运维任务之需求满足。
246 18
|
4月前
|
机器学习/深度学习 API 异构计算
JAX快速上手:从NumPy到GPU加速的Python高性能计算库入门教程
JAX是Google开发的高性能数值计算库,旨在解决NumPy在现代计算需求下的局限性。它不仅兼容NumPy的API,还引入了自动微分、GPU/TPU加速和即时编译(JIT)等关键功能,显著提升了计算效率。JAX适用于机器学习、科学模拟等需要大规模计算和梯度优化的场景,为Python在高性能计算领域开辟了新路径。
386 0
JAX快速上手:从NumPy到GPU加速的Python高性能计算库入门教程
|
4月前
|
存储 数据采集 数据处理
Pandas与NumPy:Python数据处理的双剑合璧
Pandas与NumPy是Python数据科学的核心工具。NumPy以高效的多维数组支持数值计算,适用于大规模矩阵运算;Pandas则提供灵活的DataFrame结构,擅长处理表格型数据与缺失值。二者在性能与功能上各具优势,协同构建现代数据分析的技术基石。
363 0
|
3月前
|
数据采集 机器学习/深度学习 人工智能
Python:现代编程的首选语言
Python:现代编程的首选语言
292 102

热门文章

最新文章

推荐镜像

更多