百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术分类 > 正文

python编程系列教程:6-unpack解惑

ztj100 2025-03-06 22:02 5 浏览 0 评论

本节我们细讲一下unpack的内容,和函数以及之前的多个变量同时命名都有关联。

a, b = 0, 1
while a < 10:
    print(a)
    a, b = b, a+b

还记得这个上面这段fib代码吗?

它与普通赋值语句不同的是,同时给两个变量进行赋值。

demonstrating that the expressions on the right-hand side are all evaluated first before any of the assignments take place. The right-hand side expressions are evaluated from the left to the right.

写了这么多段代码,它们的执行顺序都是从上至下,从左到右依次进行,但是到了这里却变成了先执行等号右边的,再执行等号左边的。在等号右边是从左到右执行,左边同样如此

a, b = 0, 1
while a < 10:
    print(a)
    a, b = b, a+b
    
# b, a+b将首先执行,这段代码是从左到右依次执行的。
# a,b在等号右边的值执行完成后,才开始执行。才开始执行。

在我们学习完函数的参数定义与使用(4.8. More on Defining Functions)后,我们现在再来理解这段代码

请在python官网的解释器中运行下面的代码

4, 5
a = 4, 5
print(a)
type(a)
print(a[0])
type(a[0])

发现了什么?我们输入的数字居然变成了元祖(tuple)! 元祖和列表(list)、字符(str)一样,可以通过索引(index)来进行取值。python中的+, -, *等符号叫运行符(Operators),而=, (),[]等等叫分割符(Delimiters), 我们后面还会碰到很多其它的符号,暂时无须关心。而字符串之间不能用空格分割,而字符串内部可以有空格,比如以下代码:

4 5
"4 5"

那我们继续运行以下代码呢?

a = 4, 5
a, b = 4, 5
a, b = 4, 5, 6 #ValueError: too many values to unpack (expected 2)
a, *b = 4, 5, 6 
print(a, b)

可恶啊,第三行代码报错了,为什么?你注意到报错信息了吗?注意关键线索"unpack"!也就是解构,我们在"4.8.2. Keyword Arguments"中见到过。这里的*号就是在接收多个参数,我们知道当执行多个变量同时赋值运算时(如上面的代码),等号右边的代码会首先执行。

a, *b = 4, 5, 6 # 4, 5, 6 会首先执行
4, 5, 6 # 但他们会被解释器解释成为元祖,但元祖会成为一个对象,如4, 5, 6是三个对象,但(4, 5, 6)就成了一个对象
a, *b # 此时a和b要进行赋值,对于等号右边执行完的代码,它们面对的只有一个对象:元祖,想要拿到对应的值,就得unpack解构
* # *号作为一种运算符,在这里被解释器解释成为uppack的动作,4*5是乘法,但在这里是接收元祖(5,6)
a, *b ==> 4, 5, 6 # 两边的参数数量并不对应,(4, 5, 6)被拆开后,按顺序赋值给等号左边的a和b
print(a, b)       # a拿到了4后,还剩下两个值5和6,但只有一个值b,因为有*号存在,所以5和6都以元祖的形式给了*b。

总结一下a, *b = 4, 5, 6的执行流程:

4,5,6首先执行,被解释成(4, 5, 6),a和b要拿到值,需要把这个元祖拆开按顺序取值,4被a取走后,因为*号的存在,5和6会直接以元祖的形式提供给*b,(5,6)继续解构,因为按顺序取值,该类型一定是可修改的,因此b最后变成了list,注意tuple是不可以修改的。

在解释器中执行以下代码,帮助理解上面的内容

a = (1, 2)
a[0] = 3
a
a = [1, 2]
a[0] = 3
a

至此,你应该能完全理解fib的代码了, 如果还是不理解,请反复执行上面的示例代码和阅读解释的内容。

a, b = 0, 1
while a < 10:
    print(a)
    a, b = b, a+b

上面的*号都是用来接收参数的,但是*号还可以反过来把参数列表给拆开送出去。这个内容在"4.8.5. Unpacking Argument Lists"中官方解释过:

list(range(3, 6))
args = [3, 6]
list(range(*args))

# 上面的代码看不懂?我们来点简单的
a=[1, 2, 3, 4]
print(*a)
print(a)
print(1,2,3,4)

运行发上面的代码,你会发现这里的*号和上面的*号作用相反,上面的*会接收一个tuple把多个值给到一个变量身上。但这里是把变量里的多个值分别送出去,一个是用来接收的,一个是用来输送的。这里要注意区别一下*的这两种用法的不同作用。

此时你已理解了解构(unpack)的内容了,unpack概念在函数中的变量传参经常遇到。

一个星号是接收变量,但两个星号是在接收字典,但是它们的顺序不能变,请看以下的代码

def out_print(a, *b, **c):
    print('a:', a)
    print('b:', b)
    print('c:', c)

out_print(1, 2, 3, 4, 5, c=6)
out_print(c=6, 1, 2, 3, 4, 5) # 错误的使用顺序
out_print(1, 2, c=6, 3, 4, 5) # 错误的使用顺序

def out_print(*b, **c): 
    print('b:', b)
    print('c:', c)

def out_print(*b): 
    print('b:', b)

def out_print(**c): 
    print('c:', c)

def out_print(a, **c, *b): # 错误的定义顺序
    print('a:', a)
    print('b:', b)
    print('c:', c)

def out_print(*b, **c, a): # 错误的定义顺序
    print('a:', a)
    print('b:', b)
    print('c:', c)

经过这几节的学习与代码输入,你应当熟悉了这种代码输入形式的工作方式,接下来我们暂停python编程的学习,开始学习linux系统。在熟悉了linux系统后,我们开始编译属于自己的python解释器,并使用它进行接下来的python编程学习。

接下来请阅读“linux系统系列教程:1-隐藏到幕后的linux”的内容。

相关推荐

使用 Pinia ORM 管理 Vue 中的状态

转载说明:原创不易,未经授权,谢绝任何形式的转载状态管理是构建任何Web应用程序的重要组成部分。虽然Vue提供了管理简单状态的技术,但随着应用程序复杂性的增加,处理状态可能变得更具挑战性。这就是为什么...

Vue3开发企业级音乐Web App 明星讲师带你学习大厂高质量代码

Vue3开发企业级音乐WebApp明星讲师带你学习大厂高质量代码下栽课》jzit.top/392/...

一篇文章说清 webpack、vite、vue-cli、create-vue 的区别

webpack、vite、vue-cli、create-vue这些都是什么?看着有点晕,不要怕,我们一起来分辨一下。...

超赞 vue2/3 可视化打印设计VuePluginPrint

今天来给大家推荐一款非常不错的Vue可拖拽打印设计器Hiprint。引入使用//main.js中引入安装import{hiPrintPlugin}from'vue-plugin-...

搭建Trae+Vue3的AI开发环境(vue3 ts开发)

从2024年2025年,不断的有各种AI工具会在自媒体中火起来,号称各种效率王炸,而在AI是否会替代打工人的话题中,程序员又首当其冲。...

如何在现有的Vue项目中嵌入 Blazor项目?

...

Vue中mixin怎么理解?(vue的mixins有什么用)

作者:qdmryt转发链接:https://mp.weixin.qq.com/s/JHF3oIGSTnRegpvE6GSZhg前言...

Vue脚手架安装,初始化项目,打包并用Tomcat和Nginx部署

1.创建Vue脚手架#1.在本地文件目录创建my-first-vue文件夹,安装vue-cli脚手架:npminstall-gvue-cli安装过程如下图所示:创建my-first-vue...

新手如何搭建个人网站(小白如何搭建个人网站)

ElementUl是饿了么前端团队推出的桌面端UI框架,具有是简洁、直观、强悍和低学习成本等优势,非常适合初学者使用。因此,本次项目使用ElementUI框架来完成个人博客的主体开发,欢迎大家讨论...

零基础入门vue开发(vue快速入门与实战开发)

上面一节我们已经成功的安装了nodejs,并且配置了npm的全局环境变量,那么这一节我们就来正式的安装vue-cli,然后在webstorm开发者工具里运行我们的vue项目。这一节有两种创建vue项目...

.net core集成vue(.net core集成vue3)

react、angular、vue你更熟悉哪个?下边这个是vue的。要求需要你的计算机安装有o.netcore2.0以上版本onode、webpack、vue-cli、vue(npm...

使用 Vue 脚手架,为什么要学 webpack?(一)

先问大家一个很简单的问题:vueinitwebpackprjectName与vuecreateprojectName有什么区别呢?它们是Vue-cli2和Vue-cli3创建...

vue 构建和部署(vue项目部署服务器)

普通的搭建方式(安装指令)安装Node.js检查node是否已安装,终端输入node-v会使用命令行(安装)npminstallvue-cli-首先安装vue-clivueinitwe...

Vue.js 环境配置(vue的环境搭建)

说明:node.js和vue.js的关系:Node.js是一个基于ChromeV8引擎的JavaScript运行时环境;类比:Java的jvm(虚拟机)...

vue项目完整搭建步骤(vuecli项目搭建)

简介为了让一些不太清楚搭建前端项目的小白,更快上手。今天我将一步一步带领你们进行前端项目的搭建。前端开发中需要用到框架,那vue作为三大框架主流之一,在工作中很常用。所以就以vue为例。...

取消回复欢迎 发表评论: