Python基础和变量使用

1. 基础了解

1.1 运行方式

Python有多种运行方式,以下是几种常见的执行Python代码的方法:

  • 交互式解释器: 打开终端或命令提示符,输入python或python3(取决于你的系统配置),即可进入Python交互模式。你可以直接输入代码并立即看到结果。
  • 脚本文件执行: 将Python代码保存到一个.py扩展名的文件中,例如hello.py。然后在终端或命令行中,通过python hello.py或python3 hello.py命令来运行这个脚本。
  • 集成开发环境(IDE): 如PyCharm、VS Code(配Python插件)、Jupyter Notebook等,这些环境提供了编辑、调试和运行Python代码的图形界面。
  • 在线编程平台: Repl.it、Google Colab、JupyterHub等在线平台允许用户在网页上编写并运行Python代码,无需本地安装Python环境。
  • 模块导入与作为库使用: Python代码也可以被其他Python程序作为模块导入并执行,这种方式常用于组织大型项目或开发库供他人使用。
  • 嵌入式Python: Python可以嵌入到其他应用程序中,允许在非Python环境中执行Python代码,如C/C++程序通过Python API调用Python函数。

每种方式有其特定的使用场景和优势,可根据需求选择合适的运行方式。

1.2 注释

  • 注释的作用:
  • 对关键代码的解释说明;
  • 被注释的代码不会被执行;
  • 增强代码的可读性;
  • 注释的分类:
  1. 单行注释:以#号开头,右边的所有东西都被当做说明文字,程序不进行编译运行。
# 输出
# print("he1lo wor1d")     #  注释

单独一行的注释,# 后面建议先添加一个空格,然后再编写相应的说明文字;

代码后面增加的单行注释,注释应该至少离开代码 2 个空格;

  1. 多行注释三个单引号’‘’ ‘’’ 或三个双引号 “”" “”"
'''
这是第一行
这是第二行
'''"""
这是第三行
这是第四行
"""
  1. 注释不能乱用

如果外面使用三个单引号,则里面要使用三个双引号,反之亦然。即,在嵌套使用注释的时候,两种多行注释形式交替使用

  1. 注释的排错性

先注释一部分代码,然后执行另外一部分,看看是否报错,逐层缩小报错范围,找到最终错误点。

关于代码规范

  • Python 官方提供有一系列 PEP(Python Enhancement Proposals) 文档
  • 其中第 8 篇文档专门针对 Python 的代码格式 给出了建议,也就是俗称的 PEP 8
  • 文档地址:https://www.python.org/dev/peps/pep-0008/
  • 谷歌有对应的中文文档:http://zh-google-styleguide.readthedocs.io/en/latest/google-python-styleguide/python_style_rules/

1.3 缩进规则

Python的缩进规则是Python语法中非常重要且独特的部分,它用来表示代码块的层次结构。Python中没有使用大括号 {} 来界定代码块,而是依靠缩进来区分代码块的开始和结束。
Python缩进规则的需要注意;

  1. 一致性:同一个代码块内的所有语句必须使用相同数量的空格或制表符进行缩进。推荐使用4个空格作为标准缩进量,虽然也可以使用制表符,但混合使用空格和制表符会导致错误。
  2. 严格性:Python解释器会严格检查代码块的缩进,不正确的缩进会导致IndentationError错误。
  3. 代码块定义:如if语句、for循环、while循环、def函数定义、class类定义等结构后面的第一行语句必须缩进,表示它们属于该代码块。
  4. 连续语句:同一代码块内连续的多行代码必须保持相同的缩进级别。
  5. 嵌套结构:如果一个代码块内部还有其他代码块(即嵌套结构),则内部代码块需要比外部代码块更进一步的缩进。
  6. 反向缩进结束代码块:当回到与上一层代码块相同的缩进级别时,表示当前代码块结束。对于像if语句这样可能只有单行执行语句的情况,即使只有一行,也需要正确缩进。

2. 变量

变量就是可以变化的量,量指的是事物的状态,比如人的年龄、性别,游戏角色的等级、金钱等等
为了让计算机能够像人一样去记忆事物的某种状态,并且状态是可以发生变化的。

详细地说:程序执行的本质就是一系列状态的变化,变是程序执行的直接体现,所以我们需要有一种机制能够反映或者说是保存下来程序执行时的状态。

2.1 变量的基本使用

变量使用的原则:先定义,后引用

name = 'zhangsan'     # 定义 -> 存(开辟一个内存空间,绑定变量名)print(name)           # 引用 -> 取(通过变量名访问变量值)

补充知识:(了解即可)

内存管理:垃圾回收机制

  • 垃圾回收机制(简称GC)是Python解释器自带一种机制,专门用来回收不可用的变量值所占用的内存空间。
  • 当一个变量值被绑定的变量名的个数为0时,该变量值无法被访问到,称之为垃圾。
  • 原理:Python的GC模块主要运用了“引用计数”(reference counting)来跟踪和回收垃圾。在引用计数的基础上,还可以通过“标记-清除”(mark and sweep)解决容器对象可能产生的循环引用的问题,并且通过“分代回收”(generation collection)以空间换取时间的方式来进一步提高垃圾回收的效率。

引用计数

引用计数:变量值被变量名关联的次数

# 垃圾:当一个变量值被绑定的变量名的个数为0时,该变量值无法被访问到,称之为 垃圾# 引用计数增加
x = 10  # 10的引用计数为1
y = x   # 10的引用计数为2
z = x   # 10的引用计数为3# 引用计数减少
del x   # 解除变量名x与值10的绑定关系,10的引用计数变为2
print(y)     # 10 不受影响
del y   #10的引用计数变为1
print(z)     # 10 不受影响
z = 12345
print(z)     # 12345 此时 10 已经没有变量名进行引用,引用计数为0  

循环引用

# 循环引用(交叉引用)=> 导致内存泄露问题
# 循环引用会导致:值不再被任何名字关联,但是值的引用计数并不会为0,应该被回收但不能被回收
l1=[111,]
l2=[222,]l1.append(l2) # 此时l1存放的是[值111的内存地址,l2列表的内存地址]
l2.append(l1) # 此时l2存放的是[值222的内存地址,l1列表的内存地址]# print(id(l1[1]))
# print(id(l2))# print(id(l2[1]))
# print(id(l1))# print(l2)
# print(l1[1])del l1   # 列表1的引用计数减1,列表1的引用计数变为1(还有一个间接引用)
del l2   # 列表2的引用计数减1,列表2的引用计数变为1(还有一个间接引用)
# 此时两个列表会出现永远取不到,但是引用计数不为0的情况

标记清除

# 标记清除:用来解决循环引用带来的内存泄露问题
# 内存中有两块区域:堆区与栈区,在定义变量时,变量名与值内存地址的关联关系存放于栈区,变量值存放于堆区,内存管理回收的则是堆区的内容。

在这里插入图片描述

标记/清除算法的做法是当应用程序可用的内存空间被耗尽的时,就会停止整个程序,然后进行两项工作,第一项则是标记,第二项则是清除。1. 标记。通俗地讲就是:标记的过程就行相当于从栈区出发一条线,“连接”到堆区,再由堆区间接“连接”到其他地址,凡是被这条自栈区起始的线连接到内存空间都属于可以访达的,会被标记为存活
具体地:标记的过程其实就是,遍历所有的GC Roots对象(栈区中的所有内容或者线程都可以作为GC Roots对象),然后将所有GC Roots的对象可以直接或间接访问到的对象标记为存活的对象,其余的均为非存活对象,应该被清除。2. 清除。清除的过程将遍历堆中所有的对象,将没有标记存活的对象全部清除掉。直接引用指的是从栈区出发直接引用到的内存地址,间接引用指的是从栈区出发引用到堆区后再进一步引用到的内存地址,以我们之前的两个列表l1与l2为例画出如下图像:

在这里插入图片描述

当我们同时删除l1与l2时,会清理到栈区中l1与l2的内容
这样在启用标记清除算法时,发现栈区内不再有l1与l2(只剩下堆区内二者的相互引用),于是列表1与列表2都没有被标记为存活,二者会被清理掉,这样就解决了循环引用带来的内存泄漏问题。

在这里插入图片描述


分代回收

# 基于引用计数的回收机制,每次回收内存,都需要把所有对象的引用计数都遍历一遍,这是非常消耗时间的,于是引入了 分代回收 来提高回收效率,分代回收采用的是用“空间换时间”的策略。# 分代回收的核心思想:
在历经多次扫描的情况下,都没有被回收的变量,gc机制就会认为,该变量是常用变量,gc对其扫描的频率会降低,具体实现原理如下:1. 分代指的是根据存活时间来为变量划分不同等级(也就是不同的代)
2. 新定义的变量,放到新生代这个等级中,假设每隔1分钟扫描新生代一次,如果发现变量依然被引用,那么该对象的权重(权重本质就是个整数)加一,当变量的权重大于某个设定得值(假设为3),会将它移动到更高一级的青春代,青春代的gc扫描的频率低于新生代(扫描时间间隔更长),假设5分钟扫描青春代一次,这样每次gc需要扫描的变量的总个数就变少了,节省了扫描的总时间,接下来,青春代中的对象,也会以同样的方式被移动到老年代中。也就是等级(代)越高,被垃圾回收机制扫描的频率越低
3. 回收依然是使用引用计数作为回收的依据

在这里插入图片描述

# 分代回收的缺点:
例如一个变量刚刚从新生代移入青春代,该变量的绑定关系就解除了,该变量应该被回收,但青春代的扫描频率低于新生代,所以该变量的回收就会被延迟。

2.2 变量的三大组成部分

变量的定义由变量名等号变量值三部分组成。

变量名 = 变量值
# 变量名  相当于门牌号,指向值所在的内存地址,是访问至值的唯—方式。
# =号    为赋值符号,用来将变量值的内存地址绑定给变量名。
# 变量值  就是我们存储的数据,反映的是事物的伏态。# 例如:
name = "jason"     #记下人的名字为"Jason"
sex ='男'          #记下人的性别为男牲
age = 18           #记下人的年龄为18岁
salary = 30080.1   #记下人的薪资为30000.1元

解释器执行到变量定义的代码时会申请内存空间存放变量值,然后将变量值的内存地址绑定给变量名.

2.3 变量名的命名的规则

变量名的命名原则:见名知意

  • 变量名只能是 字母数字下划线的任意组合

  • 变量名的第一个字符不能是数字

  • 关键字不能声明为变量名,常用关键字如下:

import keyword;          # 引入模块
print(keyword.kwlist);   # 打印关键字
['and', 'as', 'assert', 'break', 'class', 'continue', 'def', 'del', 'elif', 'else', 'except', 'exec', 'finally', 'for', 'from','global', 'if', 'import', 'in', 'is', 'lambda', 'not', 'or', 'pass', 'print', 'raise', 'return', 'try', 'while', 'with', 'yield']

PS:不要用拼音,不要用中文,在见名知意的前提下尽可能短(规范)。

变量名的命名风格

  • 纯小写加下划线的方式(在python中,关于变量名的命名 推荐 使用这种方式)

    age_of_alex = 73
    print(age_of_alex)
    
  • 大驼峰法(首字母大写)

    AgeOfAlex = 73
    print(AgeOfAlex)
    

2.4 变量值三个重要的特征

  • id:反映的是变量值的内存地址,内存地址不同id则不同

  • type:不同类型的值用来表示记录不同的状态

  • value:值本身

name = 'zhangsan'print(id(name))    # id = 2429388598384 
print(type(name))  # <class 'str'>
print(name)        # zhangsan

补充:

is 与 == 的区别

  • is:比较左右两个值身份id是否相等
  • ==:比较左右两个值他们的值value是否相等

id不同的情况下,值有可能相同,即两块不同的内存空间里可以存相同的值

id相同的情况下,值一定相同,x is y成立,x == y也必然成立

x='info:18'
y='info:18'
print(x,y)
info:18 info:18     # value相同print(id(x),id(y))
4565819264 4566192176   # id不同print(x == y)  # True
print(x is y)  # False

内存优化机制:小整数池[-5,256]

  • 从python解释器启动那一刻开始,就会在内存中事先申请好一系列内存空间存放好常用的整数。
  • 其取值范围在[-5,256]之间。
x=-5
y=-5
print(x is y)   # Truex=-6
y=-6
print(x is y)   # False

2.5 常量:不变的量

注意:python语法中没有常量的概念,但是在程序的开发过程中会涉及到常量的概念。

小写字母全为大写代表常量,这只是一种约定、规范。

AGE_OF_ALEX = 73
AGE_OF_ALEX = 74

单从语法层面去讲,常量的使用与变量完全一致。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/403661.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

设计模式---构建者模式(Builder Pattern)

构建者模式&#xff08;Builder Pattern&#xff09; 是一种创建型设计模式&#xff0c;旨在将复杂对象的构建过程与其表示分离。它允许使用相同的构建过程创建不同的表示。该模式通常用于构建复杂对象&#xff0c;这些对象由多个部分组成或具有多个可选属性。 构建者模式的核…

Python做统计图之美

Python数据分析可视化 案例效果图 import pandas as pd import matplotlib.pyplot as plt import matplotlib# 数据 data {"房型": [1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11],"住宅类型": ["普通宅", "普通宅", "普通宅", &q…

ffmpeg开发者视频剪辑器

5G 时代的来临&#xff0c;加速了视频类作品的创作&#xff0c;由于现在的流量越来越便宜&#xff0c;网速越来越快&#xff0c;特别是流量无限用套餐&#xff0c;大家更愿意去看视频作品&#xff0c;特别是抖音的兴起&#xff0c;更是加速了小视频的流量。不会剪辑的我们该如何…

内网安全:跨域攻击

目录 获取域信息 利用域信任密钥获取目标域 利用krbtgt哈希值获取目标域 内网中的域林&#xff1a; 很多大型企业都拥有自己的内网&#xff0c;一般通过域林进行共享资源。根据不同职能区分的部门&#xff0c;从逻辑上以 主域和子域进行区分&#xff0c;以方便统一管理。在…

选择排序(直接选择排序与堆排序的比较)

选择排序 选择排序时间复杂度 1. 直接选择排序思考⾮常好理解&#xff0c;但是效率不是很好。实际中很少使用&#xff0c;思路是先进行遍历找到元最小的元素&#xff0c;然后与第一个进行交换 2. 时间复杂度&#xff1a;O&#xff08;&#xff09; 3. 空间复杂度&#…

openharmony 南向开发基础:ohos自定义子系统,自定义部件,调用hilog部件,hilog日志封装傻瓜式教程

openharmony 南向开发基础:ohos自定义子系统,自定义部件,调用hilog部件,hilog日志封装 自定义单部件 关于开源鸿蒙的南向教程不多,很多都是从官方文档上抄的的例子,官网的例子不是很适合入门,写的很粗糙,不适合傻瓜阅读,毕竟对于刚入行鸿蒙的新手而言,gn语法就是第一劝退魔咒…

vue 路由用法 router-view

通过router-view 点击子路由显示子路由关于我们的内容&#xff0c;点击关于信息显示关于信息内容。

map/set和unordered_map/unordered_set的区别及使用情况

map/set和unordered_map/unordered_set的区别 容器底层数据结构是否有序实现版本复杂度迭代器map/set红黑树有序C98O(logN&#xff09;双向迭代器unordered_map/unordered_set哈希表/散列表无序C11O(1)单向迭代器 unordered_set无序的&#xff08;VS下&#xff09; void uno…

【机器学习】探索数据矿藏:Python中的AI大模型与数据挖掘创新实践

&#x1f496; 前言&#xff1a;探索数据矿藏1. &#x1f4ca;数据获取与预处理&#xff1a;AI大模型的燃料1.1 &#x1f310;数据获取&#xff1a;多样性与规模并重1.2 &#x1f9f9;数据清洗与处理&#xff1a;提升数据质量1.3 &#x1f50d;特征工程&#xff1a;挖掘数据的深…

蓝牙音视频远程控制协议(AVRCP) command跟response介绍

零.声明 本专栏文章我们会以连载的方式持续更新&#xff0c;本专栏计划更新内容如下&#xff1a; 第一篇:蓝牙综合介绍 &#xff0c;主要介绍蓝牙的一些概念&#xff0c;产生背景&#xff0c;发展轨迹&#xff0c;市面蓝牙介绍&#xff0c;以及蓝牙开发板介绍。 第二篇:Trans…

[Qt][QSS][下]详细讲解

目录 1.样式属性0.前言1.盒模型(Box Model) 2.常用控件样式属性1.按钮2.复选框3.单选框4.输入框5.列表6.菜单栏7.注意 1.样式属性 0.前言 QSS中的样式属性⾮常多&#xff0c;不需要都记住&#xff0c;核⼼原则是⽤到了就去查 ⼤部分的属性和CSS是⾮常相似的 QSS中有些属性&am…

稚晖君发布5款全能人形机器人,开源创新,全能应用

8月18日&#xff0c;智元机器人举行“智元远征 商用启航” 2024年度新品发布会&#xff0c;智元联合创始人彭志辉主持并发布了“远征”与“灵犀”两大系列共五款商用人形机器人新品——远征A2、远征A2-W、远征A2-Max、灵犀X1及灵犀X1-W&#xff0c;并展示了在机器人动力、感知、…

爱心商城系统pf

TOC springboot424爱心商城系统pf 第1章 绪论 1.1 课题背景 二十一世纪互联网的出现&#xff0c;改变了几千年以来人们的生活&#xff0c;不仅仅是生活物资的丰富&#xff0c;还有精神层次的丰富。在互联网诞生之前&#xff0c;地域位置往往是人们思想上不可跨域的鸿沟&…

在亚马逊云科技上安全、合规地创建AI大模型训练基础设施并开发AI应用服务

项目简介&#xff1a; 小李哥将继续每天介绍一个基于亚马逊云科技AWS云计算平台的全球前沿AI技术解决方案&#xff0c;帮助大家快速了解国际上最热门的云计算平台亚马逊云科技AWS AI最佳实践&#xff0c;并应用到自己的日常工作里。 本次介绍的是如何在亚马逊云科技利用Servi…

Mac电脑虚拟机安装win11教程

Mac分享吧 文章目录 效果一、准备工作二、安装步骤方法1&#xff1a;使用虚拟机自带的win11系统&#xff0c;选中系统软件--继续--安装&#xff0c;即可完成win11安装方法2&#xff1a;通过下载好的镜像安装Windows11系统。选择镜像文件位置&#xff0c;安装&#xff0c;配置1…

前后端项目交互异步请求JSON数据类型后端标准响应数据格式

java同步请求 当网页与后端交互时,前端不能再进行其他操作 服务器响应回来的内容,会把整个浏览器中的内容覆盖 这种请求方式在前后端交互时不太友好 现在的前后端交互请求都使用异步请求 异步请求(不同步) 通过在前端中使用js中提供的XMLHttpRequest对象实现发送异步请求…

算法的学习笔记—二叉树的镜像(牛客JZ27)

&#x1f600;前言 在二叉树相关的问题中&#xff0c;镜像操作是一个非常经典且常见的题目。本文将通过一道具体的题目&#xff0c;详细讲解如何将一棵二叉树转换为它的镜像&#xff0c;并提供实现该操作的Java代码示例。 &#x1f3e0;个人主页&#xff1a;尘觉主页 文章目录 …

CRNN不定长验证码识别

原文:CRNN不定长验证码识别 - 知乎 (zhihu.com) 一、不定长验证码识别 关于验证码识别的任务,我们可以通过使用卷积神经网络采用多标签分类的方法来完成,但是当验证码是不定长的时候,就无法使用多标签分类的方法来解决了,在这类任务中,识别的目标是类似于序列的长条形图…

React原理之Fiber详解

前置文章&#xff1a; React原理之 React 整体架构解读React原理之整体渲染流程 -----读懂这一篇需要对 React 整体架构和渲染流程有大致的概念 &#x1f60a;----- 在React原理之 React 整体架构解读中&#xff0c;简单介绍了 Fiber 架构&#xff0c;也了解了 Fiber 节点的…

IT服务标准化知识体系攻略(至简)

标准是为了在一定范围内获得最佳秩序 &#xff0c;经协商一致制定并由公开机构批准共同使用和重复使用的和中规范性文件。标准是标准化活动的主要成果之一。国家标准的制定有一套正常程序&#xff0c;分为预阶段、立项阶段、起草阶段、征求意见阶段、审查阶段、批准阶段、出版阶…