0.说明

学习Python其实也有好一段时间了,之前也做了不少笔记,但是要真正把Python学得很扎实,没有对Python系统的了解是远远不够的,哪怕是最基础的知识点,所以决定好好地回顾整理。

当然,就以《Python核心编程》这本书为纲,希望可以把自己对Python的理解连成系统的一条线。


1.语句和语法

  • `#`:注释

  • `\`:换行,如果是闭合操作符如`( )`,`[ ]`,`{ }`等,可以不使用`\`

  • `:`:分号将代码头和代码体分开

  • `缩进`:用以区分不同的代码块

  • `;`:同一行写多个语句,但不建议

  • `模块`:一个.py脚本文件就是一个模块


2.变量赋值

(1)赋值操作符:=

  • 在Python中,对象是通过引用传递的,赋值时,是将该对象的引用(不是一个值)赋给这个变量。

  • 另外,Python赋值语句没有返回值,但可以使用赋值链:

>>> a  =  (a = 3)File "<stdin>", line 1a = (a=3)^
SyntaxError: invalid syntax
>>> y = x = 3

(2)增量赋值

  • 只有类似+=这样的增量赋值,没有自增自减的方法

  • 特性:可变对象(列表,字典等)就修改(无需拷贝引用),不可变对象(数字,元组等)则分配一个新对象

(3)多重赋值

  • 一个对象可被多个变量引用,多个对象也可被多个对象引用

>>> x = y = z =1

(4)多元赋值:元组赋值

>>> (x, y, z) = (1, 2, 'a string')
  • 不加括号也可以,但建议加上

  • 可用于两值的交换

>>> x = 3; y = 4
>>> print x, y
3 4
>>> x, y = y, x
>>> print x, y
4 3

3.标识符

  • 关键字标识符:保留字,不能用于其他用途,否则会引起SyntaxError异常

  • 内建(built-in)标识符:是__builtins__模块的成员,在程序开始或交互解释器开始时,由Python解释器自动导入,可以将其作为Python全局变量,可以重新赋值,但不建议

>>> dir
<built-in function dir>
>>> dir()
['__builtins__', '__doc__', '__name__', '__package__']
  • __专用下划线标识符:

    __xxx:类中的私有变量名,不能用`from module import *`导入,变量是私有时,建议使用这种方法

    __xxx__:系统定义名字,如内建标识符

另外,Pythonn不支持标识符重载,所以任何时刻都只有一个名字绑定。


4.基本风格指南

  • 注释:#号

  • 文档:模块,类声明或函数声明中第一个没有赋值的字符串,可通过obj.__doc__访问

  • 缩进:以空格代替制表符

  • 标识符名称:名字简短有意义

  • Python风格指南:import this

(1)模块结构和布局

  • 起始行(Unix)

#/usr/bin/env python

这样仅输入脚本名字就可以执行脚本,无需直接调用解释器。

  • 模块文档

''this is a test module''

可通过obj.__doc__访问

  • 模块导入

  • 变量定义:尽量使用局部变量代替全局变量

  • 类定义

  • 函数定义

  • 主程序

if __name__ == '__main__':My_function()
#如果模块是被导入,__name__的值为模块名字;
#如果模块是被直接执行,__name__的值为'__main__';

关于主程序,注意下面几点:

  • 1.绝大部分模块创建的目的是被其它模块导入而不是作为脚本执行,总之只有一个模块,也就是包含主程序的模块会被执行;

  • 2.最高级别的Python语句(没有缩进)在模块被导入时就会被执行;

  • 3.通常只有主程序模块中有大量的顶级可执行代码,所有其他被导入模块只应该有很少的顶级执行代码,所有的功能代码都应该封装在函数或类当中。

    对于上面三点,只要联系自己在实际项目开发中的例子就可以很好的理解了。

(2)在主程序中书写测试代码

如果想测试被导入的模块的某个函数的功能,就可以使用主程序的方法,引入并执行该函数,这就是测试功能的使用,当然在大型程序中,更倾向使用unittest。


5.内存管理

  • 变量定义:变量无须事先声明

    在Python中无需显式变量声明语句,变量在第一次赋值时自动声明。

  • 动态类型:变量无须指定类型

    Python中对象的类型和内存占用都是运行时确定的。

  • 内存分配:不用关心内存管理

    Python解释器承担了内在管理的复杂任务。

  • 引用计数:对象回收

(1)增加引用计数

  • 当对象被创建并(将其引用)赋值给变量时,该对象的引用计数就被设置为1

  • 当一个对象(的引用)又被赋值给其他变量时,或作为参数传递给函数,方法或类实例时,或者被赋值为一个窗口对象(列表,字典等)的成员时,该对象新的一个引用会被创建,引用计数加1

>>> x = 3.14    #加1,下面每一步同理
>>> y = x
>>> foobar(x)
>>> myList = [123, x, 'xyz']

(2)减少引用计数

  • 一个本地引用离开其作用范围

    如函数执行完毕后局部变量被销毁。

  • 对象别名被显式销毁

>>> del y
  • 当变量被赋值给另外一个对象时,原对象的引用计数也会自动减1

>>> foo = 'xyz'
>>> bar = foo
>>> foo = 123
  • 对象被从一个窗口对象中移除

myList.remove(x)
  • 窗口对象本身被销毁

del myList

即执行del y会产生下面两个结果:

  • 1.从现在名称空间中删除y

  • 2.y变量对应的对象的引用计数减1

    需要注意的是,如果内存中仍然有在使用该对象,这会增加一个额外的引用,则它还不会被回收。

  • 垃圾收集

解释器跟踪对象的引用计数,垃圾收集器负责释放内存。其实际,垃圾收集器是一块独立代码,用来查找引用计数为0的对象和那些引用计数虽然大于0但也应该被销毁的对象(如循环引用的对象)。

垃圾收集器 = 引用计数器 + 循环垃圾计数器,这在存在循环引用的情况中非常有用:

  • 循环引用:发生在至少两个对象互相引用时,也就是当其它所有对它们的引用都消失时,他们两者所产生的对各自的引用仍然存在,例如两个类中有各自的一个实例

  • 引用计数器作用:当一个对象的引用计数变为0,解释器会暂停,释放掉这个对象和仅有这个对象可访问(可到达的)其它对象(这样的话,其它对象的引用计数必然是1)

  • 循环垃圾计数器作用:作为引用计数器的补充,垃圾收集器也会留心被分配的总量很大的(及未通过引用计数销毁的那些)对象,在这种情况下,解释器也会停下来,试图清理所有未引用的循环

基本可以理解,但具体怎么实现的,就需要看Python的源码分析了。


6.第一个Python程序

主要提及一点:使用局部变量替换模块变量

例如,你要使用os.linesep,如果你多次使用,那么建议将其定义为一个本模块的全局变量或局部变量,这将会加快查询的速度,因为对于os.linesep,要进行下面两步:

  • 首先要查找os,确认其是一个模块

  • 在这个模块中查找linesep变量

    将经常用到的模块属性替换为一个本地引用,可以让程序跑得更快。

转载于:https://blog.51cto.com/xpleaf/1750127

Python回顾与整理1:Python基础相关推荐

  1. Python回顾与整理5:映像和集合类型

    0.说明 依然是按照前面介绍的几种序列类型的思路来总结字映像类型和集合类型,即先做一个介绍,再讨论可用操作符.工厂函数.内建函数和方法. 1.映射类型:字典 映射类型被称做哈希表,而Python中的字 ...

  2. python学习-大牛整理!Python学习方法和学习路线,看完茅塞顿开!

    原标题:大牛整理!Python学习方法和学习路线,看完茅塞顿开! Python 是一种极具可读性和通用性的编程语言.Python 这个名字的灵感来自于英国喜剧团体 Monty Python,它的开发团 ...

  3. python index false_整理了 Python新手 最容易犯错的 10个坑!

    原标题:整理了 Python新手 最容易犯错的 10个坑! 相比于其他语言,Python 的语法比较简单易学,但一旦不注意细节,刚入门的新手就会掉进语法错误的坑里.今天给大家讲几个平常比较容易掉的&q ...

  4. python预测算整理集合 python根据历史数据,预测未来数据 神经网络时间序列预测python 销售收入分析与预测 神经网络预测控制 Python 源码 4个lstm做数据预测的案例源代码

    python 预测未来/神经网络/负荷/飞机零件故障/链路预测程序源码 1.python实现TensorFlow2股票股价预测(源码) 2.负荷预测(py thon例子,实时负荷预测,15分钟到4小时 ...

  5. Python回顾与整理12:执行环境

    作为<Python核心编程>核心部分的最后一章,这篇的内容也相当重要.对于高级部分的整理,将采用<Python核心编程>第三版,但是,方式会以之前的完全不一样了. 1.可调用对 ...

  6. Python回顾与整理10:模块

    模块是用来组织Python代码方法的方法,而包则是用来组织模块的,充分利用好包和模块将有利于开发出结构清晰的大型程序. 1.什么是模块 所谓模块,其实就是一个包含了特定功能代码的.py文件,在这个.p ...

  7. python 代码-我整理的Python代码规则

    首先,python有两个版本,一个是Python2.X,一个是Python3.X,目前Python3.X越来越普及,这两个版本是不兼容的,但由于我所用的大部分学习资料是用Python2.X的语法规则写 ...

  8. python代码-我整理的Python代码规则

    首先,python有两个版本,一个是Python2.X,一个是Python3.X,目前Python3.X越来越普及,这两个版本是不兼容的,但由于我所用的大部分学习资料是用Python2.X的语法规则写 ...

  9. Python学习笔记整理(三)Python中的动态类型简介

    Python中只有一个赋值模型 一.缺少类型声明语句的情况 在Python中,类型是在运行过程中自动决定的,而不是通过代码声明.这意味着没有必要事声明变量.只要记住,这个概念实质上对变量,对象和它们之 ...

最新文章

  1. 转换汉字为unicode形式的字符串和转换unicode形式字符串转换成汉字
  2. Spark _30_SparkStreaming算子操作Driver HA
  3. 分布式键值系统Amazon Dynamo简介
  4. oracle数据导入导出
  5. 数学--矩阵快速幂详解
  6. C++实现链式存储二叉树
  7. 信息学奥赛一本通(1214:八皇后)
  8. Exchange安装过程中经常遇到的服务器需要重启问题
  9. 压测工具下载地址说明及汇总
  10. 计算机怎么硬盘重做系统,怎么为双硬盘的电脑重装系统
  11. oracle新建定时任务,Oracle 定时任务详解
  12. 诛仙手游android转苹果,诛仙手游安卓和iOS互通吗 安卓和iOS能不能一起玩
  13. Activity透明主题导致behind Activity重绘的解决方法
  14. 21个令程序员泪流满面的瞬间 ...
  15. IP解析成地址 确定省市
  16. 伤感!!!!!!!!!!!!!!!
  17. 关于小米安装app的问题
  18. 数据结构算法 - ConcurrentHashMap 源码解析
  19. Docker容器与容器云
  20. debug和汇编编译器masm对指令不同的处理

热门文章

  1. Matlab某医院用光电比色计,数理统计答案(研究生).ppt
  2. DeepLearning:pydot安装的使用和安装
  3. SLAM算法总结——经典SLAM算法框架总结
  4. 【直播回放】2小时全面剖析图像分类任务,学习CV必知
  5. 【TensorFlow2.0】数据读取与使用方式
  6. 2022版全球及中国煤矿机械再制造行业“十四五”发展规划与投资建议报告
  7. 全球与中国光电通信芯片市场数据专项调研及竞争格局分析报告2022-2028年版
  8. 全球及中国吉他霉素预混剂行业创新现状与可持续发展分析报告2022-2027年版
  9. ListView图片不显示 Application.EnableVisualStyle bug
  10. 深入浅出 5种IO模型。