记录一下Python学习过程中的一些问题:


1. 在JupyterLab中查询当前文件的地址

import os
print(os.getcwd())
#查询该文件的地址

2. 新建cell

在 JupyterLab 中新建一个单元格(cell)的方法有多种,以下是一些常用的方法:

  1. 使用快捷键

    • B:在当前单元格下方新建一个单元格。
    • A:在当前单元格上方新建一个单元格。

实测有效,虽然看起来挺神奇的,确实方便

  1. 使用工具栏按钮

    • 在工具栏上,你可以找到用于添加单元格的按钮。通常,这些按钮位于工具栏的中间部分,看起来像是一个带有加号的单元格图标。
  2. 使用右键菜单

    • 在工作区的空白处或者在已有单元格的边缘右键点击,然后选择“Insert Cell Above”或“Insert Cell Below”来在相应位置插入新单元格。
  3. 使用命令面板

    • 点击工具栏上的 "Commands" 图标(或者使用快捷键 Ctrl+Shift+P),在命令面板中搜索 "Insert Cell Below" 或 "Insert Cell Above" 并选择它。
  4. 拖拽单元格

    • 你可以将一个单元格拖拽到工作区的空白处,然后释放鼠标,这将在该位置创建一个新的单元格。
  5. 使用菜单

    • 在 JupyterLab 的菜单栏中,点击 "Insert",然后选择 "Insert Cell Below" 或 "Insert Cell Above"。
  6. 使用侧边栏

    • 在 JupyterLab 的侧边栏中,点击 "+" 图标,然后选择 "Code" 或 "Markdown" 来创建一个新的单元格。
  7. 使用拖拽文件

    • 你也可以将一个 .py.ipynb 文件拖拽到 JupyterLab 的工作区中,这将创建一个新的单元格或打开一个新笔记本。

选择适合你的方法来新建单元格,然后你就可以在新单元格中输入代码或 Markdown 文本了。

3. 集合、列表、元祖的区别

在 Python 中,集合(set)、列表(list)和元组(tuple)是三种不同的数据结构,它们各自有不同的特性和用途:

  1. 列表(List)

    • 列表是可变的,这意味着你可以在创建后修改它们(添加、删除或更改元素)。
    • 列表可以包含重复的元素。
    • 列表是有序的,即它们保持元素插入的顺序。
    • 列表可以包含不同类型的元素。
    • 列表支持索引和切片操作。
    • 列表的典型用法包括创建一个有序的元素集合,或者当你需要修改集合中的元素时。
  2. 元组(Tuple)

    • 元组是不可变的,一旦创建就不能修改(不能添加、删除或更改元素)。
    • 元组可以包含重复的元素。
    • 元组也是有序的,并且支持索引和切片操作。
    • 元组可以包含不同类型的元素。
    • 元组通常用于存储不应该改变的数据。
    • 元组是创建不可变集合的推荐方式,它们还可以用作字典的键(因为字典的键必须是不可变的)。
  3. 集合(Set)

    • 集合是无序的,这意味着集合中的元素没有固定的顺序,并且可能会在每次迭代时改变。
    • 集合是可变的,你可以添加或删除元素。
    • 集合不能包含重复的元素,每个元素都是唯一的。
    • 集合不支持索引操作,因为它们是无序的。
    • 集合的典型用法包括消除重复元素、进行集合运算(如并集、交集、差集)。
    • 集合是不可哈希的,因此不能用作字典的键。

以下是一些示例:

# 列表
my_list = [1, 2, 3, 4, 5]
my_list.append(6) # 添加元素
my_list[1] = 20 # 修改元素 # 元组
my_tuple = (1, 2, 3, 4, 5)
# my_tuple[1] = 20 # 这会引发 TypeError,因为元组是不可变的 # 集合
my_set = {1, 2, 3, 4, 5}
my_set.add(6) # 添加元素
# my_set[1] # 这会引发 TypeError,因为集合不支持索引

选择使用哪种数据结构取决于你的具体需求,比如是否需要有序性、是否允许重复元素、是否需要修改集合等。


4. 张量的二维表达是矩阵

张量(Tensor)和矩阵(Matrix)是线性代数中的两个概念,它们有一定的联系,但在维度和应用上有所不同。

  1. 矩阵

    • 矩阵是一个二维数组,由行和列组成,可以看作是特殊的张量。
    • 矩阵中的元素通常用两个索引来访问,如 ( a_{ij} ),其中 ( i ) 表示行索引,( j ) 表示列索引。
    • 矩阵在数学、物理学和工程学中有广泛的应用,特别是在线性变换、系统方程和图形变换等领域。
  2. 张量

    • 张量是多维数组的推广,可以有任意数量的维度。例如,0维张量是一个标量,1维张量是一个向量,2维张量是一个矩阵。
    • 张量中的元素可以用多个索引来访问,如 ( a_{ijk} ),其中 ( i )、( j ) 和 ( k ) 分别表示不同维度的索引。
    • 张量在物理学中用于描述具有多个分量的物理量,如应力、应变等。在深度学习中,张量用于表示数据和权重,可以是多维的,以适应不同的网络结构和计算需求。

在深度学习和计算机科学中,张量的概念被广泛使用,尤其是在以下领域:

  • 神经网络:张量用于表示网络的输入、输出和权重。
  • 图像处理:图像可以表示为三维张量(高度、宽度、颜色通道)。
  • 自然语言处理:文本数据可以表示为张量,用于模型的输入和处理。

在 PyTorch 和 TensorFlow 等深度学习框架中,张量是核心数据结构,它们提供了对多维数组的高效操作,并且可以利用 GPU 加速计算。这些框架中的张量操作通常包括基本的数学运算、矩阵乘法、卷积、池化等。

Python学习(一)——配套《PyTorch深度学习实战》的更多相关文章

  1. Python自然语言处理实战核心技术与算法,Python自然语言处理,PyTorch深度学习实战【下载】

    本人买的,无私贡献给大家,无解压密码 下载地址: 链接:https://pan.baidu.com/s/1cJtnhEQSXHVMgygr8PHh9A 提取码:a54u

  2. 对比学习:《深度学习之Pytorch》《PyTorch深度学习实战》+代码

    PyTorch是一个基于Python的深度学习平台,该平台简单易用上手快,从计算机视觉.自然语言处理再到强化学习,PyTorch的功能强大,支持PyTorch的工具包有用于自然语言处理的Allen N ...

  3. 基于Ubuntu+Python+Tensorflow+Jupyter notebook搭建深度学习环境

    基于Ubuntu+Python+Tensorflow+Jupyter notebook搭建深度学习环境 前言一.环境准备环境介绍软件下载VMware下安装UbuntuUbuntu下Anaconda的安 ...

  4. PyTorch深度学习实践——反向传播

    反向传播 课程来源:PyTorch深度学习实践--河北工业大学 <PyTorch深度学习实践>完结合集_哔哩哔哩_bilibili 目录 反向传播 笔记 作业 笔记 在之前课程中介绍的线性 ...

  5. PyTorch深度学习实践——多分类问题

    多分类问题 目录 多分类问题 Softmax 在Minist数据集上实现多分类问题 作业 课程来源:PyTorch深度学习实践--河北工业大学 <PyTorch深度学习实践>完结合集_哔哩 ...

  6. PyTorch深度学习实践——处理多维特征的输入

    处理多维特征的输入 课程来源:PyTorch深度学习实践--河北工业大学 <PyTorch深度学习实践>完结合集_哔哩哔哩_bilibili 这一讲介绍输入为多维数据时的分类. 一个数据集 ...

  7. SIGAI深度学习第四集 深度学习简介

    讲授机器学习面临的挑战.人工特征的局限性.为什么选择神经网络.深度学习的诞生和发展.典型的网络结构.深度学习在机器视觉.语音识别.自然语言处理.推荐系统中的应用 大纲: 机器学习面临的挑战 特征工程的 ...

  8. 【PyTorch深度学习60分钟快速入门 】Part1:PyTorch是什么?

      0x00 PyTorch是什么? PyTorch是一个基于Python的科学计算工具包,它主要面向两种场景: 用于替代NumPy,可以使用GPU的计算力 一种深度学习研究平台,可以提供最大的灵活性 ...

  9. Python学习(二)——深度学习入门介绍

    课程二:深度学习入门 讲师:David (数据分析工程师) 这门课主要介绍了很多神经网络的基本原理,非常非常基础的了解. 零.思维导图预览:                一.深度神经网络 1.神经元 ...

  10. 【PyTorch深度学习】学习笔记之PyTorch与深度学习

    第1章 PyTorch与深度学习 深度学习的应用 接近人类水平的图像分类 接近人类水平的语音识别 机器翻译 自动驾驶汽车 Siri.Google语音和Alexa在最近几年更加准确 日本农民的黄瓜智能分 ...

随机推荐

  1. Docker Compose容器编排--项目五

    一.Docker Compose概念 Docker Compose (可简称Compose)是一个定义与运行复杂应用程序的 Docker 工具,是 Docker 官方 编排(Orchestration ...

  2. 3.1 Linux文件系统的层次结构

    通过学习<Linux一切皆文件>一节我们知道,平时打交道的都是文件,那么,应该如何找到它们呢?很简单,在 Linux 操作系统中,所有的文件和目录都被组织成以一个根节点"/&qu ...

  3. DDCA —— 缓存一致性

    1. 多处理器内存组织结构 1.1 SMP/集中式共享内存 集中式共享内存多处理器(Centralized shared-memory multiprocessor)或对称共享内存多处理器(Symme ...

  4. GPU 环境搭建指南:使用 GPU Operator 加速 Kubernetes GPU 环境搭建

    本文主要分享如何使用 GPU Operator 快速搭建 Kubernetes GPU 环境. 1. 概述 上一篇文章 GPU 使用指南:如何在裸机.Docker.K8s 等环境中使用 GPU 分享了 ...

  5. 低功耗4G模组Air780E快速入门:固件的远程升级

    ​ 今天我们学习Air780E快速入门之固件的远程升级,小伙伴们,学起来吧! 一.生成差分包 合宙的远程升级支持使用合宙云平台和自建服务器,此例程使用的是合宙云平台. 1.1 准备新旧版的core和脚 ...

  6. MySQL原理简介—5.存储模型和数据读写机制

    大纲 1.为什么不能直接更新磁盘上的数据 2.为什么要引入数据页的概念 3.一行数据在磁盘上是如何存储的 4.一行数据中的NULL值是如何处理的 5.一行数据的数据头存储的是什么 6.一行数据的真实数 ...

  7. 关于switch的优化:转移表(完结)

    用转移表来代替功能实现中的 switch 语句 1. switch 语句应用场景 在许多场景中会用到条件判断,此时简单的条件判断一般通过 if/else 语句实现:如果涉及三条以上的功能分支一般会通过 ...

  8. hashcode和equals为何要同时重写

    浅谈为何要重写 hashcode()与equals() 首先,这两个方法都来自于Object对象,根据API文档查看下原意.(1)public boolean equals(Objectobj),对于 ...

  9. Python之读写Excel

    现有的Excel分为两种格式:xls(Excel 97-2003)和xlsx(Excel 2007及以上). Python处理Excel文件主要是第三方模块库xlrd.xlwt.pyexcel-xls ...

  10. OneForAll - 功能强大的子域收集工具

    OneForAll,是 shmilylty 在 Github 上开源的子域收集工具,目前版本为 v0.4.3. 收集能力强大,利用证书透明度收集子域.常规检查收集子域.利用网上爬虫档案收集子域.利用D ...