Python基础(1):基本规则及赋值「建议收藏」

Python基础(1):基本规则及赋值「建议收藏」Python有如下的基本规则:#后表示注释\n是行分隔符\是继续上一行,将过长语句分开;分号将两个语句连接在一行中:冒号将代码头和体分开代码块用缩进块的方式体现不同缩进深度分隔不同的代码

大家好,又见面了,我是你们的朋友全栈君。

Python有如下的基本规则:   #后表示注释   \n是行分隔符   \是继续上一行,将过长语句分开   ;分号将两个语句连接在一行中   :冒号将代码头和体分开   代码块用缩进块的方式体现   不同缩进深度分隔不同的代码块   Python文件用模块的形式组织

缩进推荐风格,缩进四个空格宽度,避免使用制表符。

 

赋值语句 Python中,主要赋值运算符是等号( = ) 赋值不是直接将一个值赋给一个变量,对象是通过引用传递的。不管变量是新创建的还是已经存在的,都是将该对象的引用赋值给变量。

C语言中,赋值语句可以当成一个表达式,可以返回值。但在Python中,赋值语句不会返回值。这使得这样的语句是非法的

复制代码
>>> y = (x = x + 1) # assignments not expressions! File "<stdin>", line 1 y = (x = x + 1) ^ SyntaxError: invalid syntax >>> if (a = 3): SyntaxError: invalid syntax
复制代码

这就避免了判断语句中,将 == 符号误写成 = 的问题。是一个很好的功能。

同样的Python中链式赋值并没有问题。

复制代码
>>> y = (x = x + 1) # assignments not expressions! File "<stdin>", line 1 y = (x = x + 1) ^ SyntaxError: invalid syntax >>> if (a = 3): SyntaxError: invalid syntax
复制代码

同时还有增量赋值符

+=   -=   *=   /=   %=   **=
<<=  >>=   &=   ^=   |=

相对于普通赋值不仅仅是写法改变,最有意义的变化是第一个对象仅被处理一次。 Python不支持x++或–x这样的前置/后置自增/自减运算 多元赋值

复制代码
>>> x, y, z = 1, 2, 'a string' >>> x 1 >>> y 2 >>> z 'a string' >>> x, y, z (1, 2, 'a string')
复制代码

赋值时将等号两边的对象都看成元组

使用多元赋值的方法可以不使用中间变量直接交换表量的值

>>> x , y = 1, 2
>>> x, y
(1, 2) >>> x, y = y, x >>> x, y (2, 1)

 

专用下划线标识符

  _xxx 不用’from module import *’导入   __xxx__系统定义名字   __xxx  类中私有变量名

风格提示: 避免用下划线作为变量名的开始 下划线对于解释器有特殊的意义,而且是内建标识符所使用的符号,所以应避免下划线作为变量名的开始。一般来讲_xxx被看做私有的,在模块或类外不可使用,所以当变量是私有时,用_xxx是很好的习惯。因为__xxx__有特殊含义,所以普通变量命名应避免这种风格

关于变量的赋值部分 Python的变量的赋值都是引用。这设计到它的内存管理机制。Python使用了引用计数这一简单技术。内部记录着所有使用中的对象各有多少引用。 当对象被创建时,就创建一个引用计数,当对象不背需要时,即引用计数为0时就被垃圾回收。 当对象被创建并赋值给变量时,该对象的引用计数就被设置为 1 当同一个对象又被赋值给其它变量时,或者作为参数传递给函数,方法或类实例时,或者被赋值为一个窗口对象的成员时,该对象的一个新的引用或者称别名,就被创建(引用计数加1)

x = 2
y = x

第一句创建了一个整数对象并引用赋值给x。x是第一个引用,该对象的引用计数设置为 1 。当y = x 语句执行时,并没有为y创建一个新对象,而是该对象的引用计数增加了1次。这是引用计数的增加。同样还有作为参数被函数调用,或者对象被加到某个容器对象中时。 而当变量被赋值给另一个对象时,原对象的引用计数也会自动减 1

foo = 3
foo = '123'

当3被创建赋值给foo时,引用计数是1 。 当它重新赋值给对象’123’时,3的引用计数自动减1 当本地引用离开了作用范围,比如函数结束时。 对象别名被显式的销毁 对象别名被赋值给其他对象 对象从一个窗口对象中移除 窗口对象本身被销毁 这几个情况都会减少引用计数

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/155977.html原文链接:https://javaforall.net

(0)
上一篇 2022年7月5日 下午6:00
下一篇 2022年7月5日 下午6:16


相关推荐

  • java lang nullpointer_java.lang.throwable

    java lang nullpointer_java.lang.throwableIntentintent=registerReceiver(null,newIntentFilter(Intent.ACTION_BATTERY_CHANGED));查询电量的时候可以通过上面这种方式返回一个intent,从这个intent中也确实能够拿到我们想要要的信息,但是平常我们注册普通的广播的时候都习惯传入一个receiver,如果有电量改变就会不停的执行receiver的onR…

    2025年10月28日
    5
  • 查看三种MySQL字符集的方法

    查看三种MySQL字符集的方法

    2021年10月12日
    56
  • python逐行调试_python单步调试

    python逐行调试_python单步调试广告关闭腾讯云 11 11 云上盛惠 精选热门产品助力上云 云服务器首年 88 元起 买的越多返的越多 最高返 5000 元 本文由腾讯云 社区自动同步 原文地址 https stackoverflo clubpython debugpythonp 使用使用命令 python mpdbyour py file 进入调试界面 输入 helppdb 可以查询完整帮助信息执行命令行 debugp

    2026年3月27日
    2
  • 路飞学城python电子书_路飞学城python入门笔记01

    路飞学城python电子书_路飞学城python入门笔记01机器语言 优点最底层 速度最快 缺点最复杂 开发效率最低汇编语言 有点比较底层 速度最快 缺点最复杂 开发效率最低高级语言 高级语言所编制的程序不能直接被计算机识别必须经过转换才能被执行按转换方式可以分成两类 编译类在应用源程序执行之前 就将程序源代码翻译成目标代码 机器语言 因此其目标程序可以托利奇语言环境独立执行 使用比较方便而效率高 但应用程序一旦需要修改 必须先修改源代码 再重新编译生

    2026年3月26日
    2
  • Address Sanitizer使用指南

    Address Sanitizer使用指南提示 文章写完后 目录可以自动生成 如何生成可参考右边的帮助文档文章目录前言一 pandas 是什么 二 使用步骤 1 引入库 2 读入数据总结前言 AddressSanit 使用提示 以下是本篇文章正文内容 下面案例可供参考一 pandas 是什么 示例 pandas 是基于 NumPy 的一种工具 该工具是为了解决数据分析任务而创建的 二 使用步骤 1 引入库代码如下 示例 importnumpya

    2025年8月3日
    5
  • 三分钟彻底理解冒泡排序

    三分钟彻底理解冒泡排序0.如果遇到相等的值不进行交换,那这种排序方式是稳定的排序方式。1.原理:比较两个相邻的元素,将值大的元素交换到右边2.思路:依次比较相邻的两个数,将比较小的数放在前面,比较大的数放在后面。(1

    2022年7月2日
    31

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号