基础语法
标识符
所谓的标识符就是对变量、常量、函数、类等对象起的名字。
首先必须说明的是,python语言在任何场景都严格区分大小写!也就是说a和a代表的意义完全不同
python对于表示标识符的命名有如下规定:
第一个字符必须是字符表中的字符或者下划线
例如,a,abc,_id,等都是可以的。但是例如开头的是php的变量语法),~abc,123a都是不可以的。这一点一定要注意。
可能有人会问,中文可以作为标识符嘛?答案是可以的
另外,以下划线开头的标识符通常都有特殊意义。以单下划线开头的变量,例如_foo代表禁止外部访问的类成员,需通过类提供的接口进行访问,不能用"from xxx import *"导入。而以双下划线开头的,例如__foo,代表类的私有成员 以双下划线开头和结尾的__foo__是python里特殊方法专用的标识。如__init__代表类的构造函数。这些我们后面会专门的讨论这里不做过多的解释。
标识符的其他的部分由字母、数字和下划线组成
标识符除了首字符不可以是数字外,其他部分还可以包含数字。这里需要注意特殊字符是不可以的。
例如:
a123b,bbc,a_b_c_1这些都是可以的。但是a&b,a-b-c这些都是不可以的。
另外要注意的是,由于l(小写的l)和数字1, 大小写的o与数字0在外观上的相似性,请尽量不要让它们相邻出现,保持语义的清晰性,确保不会发现错误认读的情况。
同样,英文中夹塞中文在语法上也是可以的,但绝对不要这么做!
标识符对大小写敏感
刚刚上面也给大家说过了,标识符ab和ab是完全不同的两个标识符
变量名全部小写,常量名全部大写
这条不能算语法层面的要求,而是代码规范的要求。
可以用pi来表示一个变量,但通常我们都会认为这是代表圆周率的一个常量
函数和方法名用小写加下划线
这算是一个代码的规范,我们在定义一个方法的时候。尽量用get_images,count_apple之类的命名方式。当然也可以采用小驼峰的方式,getimages,countapple这种。
类名用大驼峰
同样也是代码规范,例如threadminxin,buttonclick这种。就是每个单词的首字母大写,组合在一起就像是驼峰一样高低排列。
模块和包的名字用小写
请尽量小写模块和包的名字,并且不要和标准库以及著名的第三方库同名。如果同名程序运行会报错。
最后提醒大家,变量的命名不要用关键字和内置函数的名称!!
python保留字
python保留字,也叫关键字,是python语言官方确定的用作语法功能的专用标识符,不能把它们用作任何自定义标识符名称。关键字只包含小写字母。可以通过python提供的库输出这些关键字
python的标准库提供了一个 keyword 模块,可以输出当前版本的所有关键字
如果真的用关键字来当做变量,会怎么样呢?
系统会直接提示语法错误,所以这里一定要注意不要用关键字来当做变量。除了不能使用关键字作为标识符,内置的函数同样也是不可以的。sum是一个求和的函数。这里我给它定义成一个字符串看看会有什么结果?
注释
我们写的程序里,不光有代码,还要有很多注释。注释有说明性质的、帮助性质的,它们在代码执行过程中相当于不存在,透明的。
单行注释
python中,以符号“#”为单行注释的开始,从它往后到本行的末尾,都是注释内容。
# 单行注释
多行注释
python没有真正意义上的多行注释(块注释)语法
#第一行注释
#第二行注释
#第三行注释
注释文档
在某些特定的位置,用三引号包括起来的部分,也被当做注释。
代码头两行
很多时候,我们在一些py脚本文件的开头都能看到类似的以#开头的这样两行代码,它们不是注释,是一些设定
第一行:用于指定运行该脚本的python解释器,linux专用,windows不需要。env方式下,系统会自动使用环境变量里指向的python。还有一种方式,#!/usr/bin/python3.6,这会强制要求使用系统中的python3.6解释器执行文件,这种方式不好,一旦你本地的python3.6版本删除了,会出现找不到解释器的错误。无论两种方式的哪一种,都指的是在linux下使用
第二行:代码的编码方式。不是程序要处理的数据的编码方式,而是程序自己本身的字符编码。在python3中,全面支持unicode,默认以utf-8编码,我们不用再纠结中文的问题,乱码的问题,所以本行其实可以不需要。但在python2中,对字符的编码是个非常令人头疼的问题,通常都需要指定这么一行。如果要自定义别的编码类型的话,可以像这样:# -- coding: cp-1252 --,但如果没有强制需求的话,不要自己作死,请坚持使用utf-8编码。
这里的-*-是什么意思呢?没意思,装饰美观好看而已
语句与缩进
语句:在代码中,能够完整表达某个意思、操作或者逻辑的最短代码,被称为语句。
这里强调一下,python的标准语言不需要使用分号。简单的换行就表示语句已经结束。
代码块:为完成某一特定功能而联系在一起的一组语句构成一个代码块。有判断、循环、函数、类等各种代码块。代码块的首行通常以关键字开始,以冒号( : )结束。比如:
python最具特色的语法就是使用缩进来表示代码块,不需要使用大括号
像php、java等语言都是使用({})来表示代码块的。python一般用四个空格就是tab来缩进。在pycharm中tab自动回转成4个空格。在linux环境中,如vim编辑器,建议使用空格。
那么怎么才是正确的缩进方式呢?
多行语句: 前面是多条语句在一行,但如果一条语句实在太长,也是可以占用多行的,可以使用反斜杠()来实现多行语句
不到迫不得已,不要使用这种,该换行就换行。
pass语句
pass语句是占位语句,它什么都不做,只是为了保证语法的正确性而写。以下场景中,可以使用pass语句:
当你不知道后面的代码怎么写的时候
当你不需要写代码细节的时候
当语法必须,又没有实际内容可写的时候
其它的一些你觉得需要的场景
字符串的表示形式
在后面的章节中,会进行更深入的介绍,这里作为一个前期的知识铺垫。
abc可能是个变量,但是"abc"肯定是个字符串了。这里强调一下在编程语言中,所有的符号都是英文状态下的。
在python中单引号和双引号的作用完全相同。在其他语言中,单双引号还是有一定区别的。
原生字符串: 通过在字符串前加r或r,如 r"this is test ",表示这个字符串里的斜杠不需要转义,等同于自身