Python基础语法(1)上

常量和表达式

我们可以把 Python 当成一个计算器,来进行一些算术运算。

print(1 + 2 - 3)

print(1 + 2 * 3)

print(1 + 2 / 3)

这里我们可能会有疑问,为什么不是1.6666666666666667呢?

其实在编程中,一般没有"四舍五入"这样的规则,这些小数在python中称为浮点数,浮点数的话专门有一套规则在内存中表示的,我们叫IEEE754标准,关于这个标准里面具体怎么规定的,我们暂且不给大家做过多解释,在这个标准之下所规定的浮点数,它在内存中表示一些数据的时候,可能会存在非常小的误差。

注意:

print 是一个 Python 内置的函数,这个稍后详细介绍。

可以使用 + - * / ( ) 等运算符进行算术运算。先算乘除,后算加减。

运算符和数字之间,可以没有空格,也可以有多个空格。但是一般习惯上写一个空格(比较美观)。

PS: 美观是否重要?

形如 1 + 2 - 3 这样的算式,在编程语言中称为表达式,算式的运算结果,称为表达式的返回值

其中 1 , 2 , 3 这种称为字面值常量,+ - * / 这种称为运算符或者操作符。

注意:熟悉 C / Java 的同学可能认为, 2 / 3 结果为 0 (小数部分被截断)。但是在 Python 中得到的结果则是一个小数,更符合日常使用的直觉。

示例

给定四个分数,67.5,89.0,12.9,32.2,编写代码,求这四个分数的平均数。

变量和类型

变量是什么

有的时候,我们需要进行的计算可能更复杂一些,需要把一些计算的中间结果保存起来,这个时候就需要用到变量。

示例

给定四个分数,67.5,89.0,12.9,32.2,编写代码,求这四个分数的方差。

PS: 方差的计算过程: 取每一项,减去平均值,计算平方,再求和,最后除以 (项数 - 1)。

在这个代码中,就需要先计算这四个数字的平均值,然后再计算方差,这就需要把计算的平均值使用变量保存起来。

avg = (67.5 + 89.0 + 12.9 + 32.2) / 4

total = (67.5 - avg) ** 2 + (89.0 - avg) ** 2 + (12.9 - avg) ** 2 + (32.2 - avg) ** 2

result = total / 3

print(result)

在python里面,x ** 后面跟一个数字表示x的几次方,例如x的平方就是 x ** 2,x的三次方就是 x ** 3。

打印的结果:

注意:

avg, total, result 均为变量。

** 在 Python 中表示乘方运算,** 2 即为求平方。

就像计算器中的 M 键功能类似,通过变量就可以保存计算过程中的中间结果。

只不过,计算器一般只能保存一个数据,而在 Python 代码中,可以创建任意多的变量,来随心所欲的保存很多很多的数据。

变量可以视为是一块能够容纳数据的空间,这个空间往往对应到 "内存" 这样的硬件设备上。

PS: 我们可以把内存想像成是一个宿舍楼,这个宿舍楼上有很多的房间,每个房间都可以存放数据。

衡量内存的一个重要指标就是内存空间的大小,比如我的电脑内存是 16GB。这个数字越大,意味着内存的存储空间就越大,能够存放的数据(变量) 就越多。

变量的语法

(1) 定义变量

a = 10

创建变量的语句非常简单, 其中

a 为变量名,当我们创建很多个变量的时候,就可以用名字来进行区分。

= 为赋值运算符,表示把 = 右侧的数据放到 = 左侧的空间中。

注意: 变量的名字要遵守一定规则。

变量命名的规则:

1.变量名必须由数字、字母、下划线构成,不能包含特殊符号

像 a1 是合法的变量名,1a、a * a都是非法的变量名

2.数字不能开头

3.变量名不能和python的关键字重复

那什么是关键字呢?关键字就是在语法中有特定含义的单词,像if这种也是非法变量名,if = 10就是非法的变量名

4.python中的变量名是区分大小写的

num = 10和Num = 10是两个不同的变量

我们所说的这几个规则都是硬性规则,硬性的意思就是必须要遵守的

软性规则(建议遵守)

1.变量名使用有描述性的单词来表示,尽量表达出变量的作用。

2.一个变量名可以由多个单词构成, 长一点没关系, 但是含义要清晰。

3.当变量名包含多个单词的时候,建议使用 "驼峰命名法",形如 totalCount ,personInfo 这种,除 了首个单词外,剩余单词首字母大写。还有蛇形命名,单词之间,使用下划线_来进行分割,形如person_info,total_count。

4.数学上, 变量通常使用 x, y, z 这种简单的英文字母或者拉丁字母表示,但是在编程中不建议这样使用。原因是编程中,一个程序里通常会同时创建出很多个变量,如果只是使用单个字母表示,在变量多了的时候,就很难记住哪个变量是干啥的,从而给维护程序带来了一定的困难,因此我们更建议使用带有明确描述性的名字,来表示变量的用途。

(2) 使用变量

读取变量的值

a = 10

print(a)#在打印a的时候,就是在读取变量中的内容

修改变量的值

a = 20

print(a)

注意: 在 Python 中,修改变量也是使用 = 运算,看起来和定义变量没有明显区别。

当然,也可以用一个变量的值赋给另外一个变量。

a = 10

b = 20

a = b

print( a )

print( b )

#首次使用 = 对a进行设置值,这个过程是创建变量,也叫做初始化

#后续再对 a 使用 = 操作,这相当于修改 a 的内容,这个操作也管它叫赋值

变量的类型

变量里面存储的不仅仅是数字,还可以存储其它种类的数据,为了区分不同种类的数据,我们引入了 "类型" 这样的概念。变量的类型就是对于不同种类的变量做出区分。

注意: 和 C++ / Java 等语言不同,Python 变量的类型不需要显式指定,而是在赋值的时候确定的。

Python 中的变量的类型,不需要在定义变量的时候显示声明,而只是依靠初始化语句,根据初始化的值的类型来进行确定的。

(1) 整数

a = 10

print( type( a ))

在 python中, int 能够表示的数据范围是"无穷的"。Java中,int最大能够表示到 -21亿到+21亿,Python中的 int 是可以根据要表示的数据的大小自动扩容(赋值更大的数据,它就能更多的分配内存空间),因此Python中就没有像long这样的类型了,像byte、short这些类型在Python中也不存在,我们表示整数就用一个统一的int。

PS: type 和 print 类似,也是 python 内置的函数,可以使用 type 来查看一个变量的类型。

注意: 和 C++ / Java 等语言不同,Python 的 int 类型变量,表示的数据范围是没有上限的,只要内存足够大,理论上就可以表示无限大小的数据。

(2) 浮点数(小数)

a = 10.0

print( type( a ))

注意:像C++和Java里面float是四个字节的,也叫做"单精度浮点数",把一个二进制位,称为一个bit,8个bit放在一起,就称为是一个字节,和 C++ / Java 等语言不同,Python 的小数只有 float 一种类型,没有 double 类型,但是实际上 Python 的 float 就相当于 C++ / Java 的 double,表示双精度浮点数。

PS: 关于单精度浮点数和双精度浮点数的问题,我们此处不做过多讨论,大家只要知道,相比于单精度浮点数,双精度浮点数占用的内存空间更多,同时表示的数据精度更高即可(大概精确到小数点后 15 位)。

(3) 字符串

a = 'hello'

print(type( a ))

使用 ' ' 或者 " " 引起来的,称为字符串,可以用来表示文本。

注意: 在 Python 中,单引号构成的字符串和双引号构成的字符串,没有区别。'hello' 和 "hello" 是 完全等价的。Python中要求使用引号把一系列的字符引起来,就构成了"字符串"。

英文字母、阿拉伯数字、标点符号、甚至是汉字符号,都可以认为是字符。

可以使用 len 函数来获取字符串的长度。

a = 'hello'

print(len( a ) )

可以使用 + 针对两个字符串进行拼接。

形如这样的代码,就是"字符串拼接" ,也就是把后面的字符串拼接到前一个字符串的末尾,得到一个更大的字符串。这个拼接操作是生成一个新的字符串,这个新的字符串叫"helloworld",换句话说,它对于我们原来的a1和a2是没有影响的。

此处是两个字符串相加,不能拿字符串和整数/浮点数相加。

如果字符串中包含了双引号,表示字符串可以就用单引号引起来,如果字符串中包含了单引号,表示字符串可以用双引号引来。Python中还有一种字符串,比如" ''' "或者" """ "来表示。目前我了解的就单引号 (')、双引号 (")、三引号 (''' 或 """) 来表示不同类型的字符串,没有四引号或更多引号的语法。

这段代码是敲代码的时候编译器不报错误,运行时报错误。

在Python中报错,有两种情况:

1.语法错误。在程序运行之前,Python解释器就能把错误识别出来

2.运行错误。在程序运行之前是识别不了的,必须执行到对应的代码,才能发现问题。

字符串作为开发中最常用到的数据类型,支持的操作方式也是非常丰富的,此处暂时不详细展开。

(4) 布尔

布尔类型是一个特殊的类型,取值只有真(True)和假(False)两种(首字母都是大写),因此,布尔类型主要用于逻辑判定。

PS: 布尔类型也是数学上的一个概念。我们初中就学过一个概念叫做 "命题",进一步的就可以判定 命题的真假。例如:

汤老湿真帅! (真命题)

汤老湿是个妹子 (假命题)

a = True

print(type( a ))

b = False

print(type( b ))

布尔类型在咱们后续进行逻辑判断的时候,是非常有用的。

(5) 其他

除了上述类型之外,Python 中还有 list、tuple、dict、自定义类型等等,我们后续再介绍。

为什么要有这么多类型?

(1) 类型决定了数据在内存中占据多大空间。

int 默认是4个字节,但是可以根据表示的数据范围动态扩容,如果表示的范围太大了,超过4个字节能表示的21亿,它就能扩容成一个更大字节。例如 float 类型在内存中固定占据 8 个字节,bool类型一个字节就够了,字符串就属于这样一个变长的变量了。

PS: 计算机里面使用二进制来表示数据,也就是每个位只能表示 0 或者 1。

1 个二进制位,就称为是一个 "比特",8 个二进制位,就称为一个 "字节" (Byte)。

一个 float 变量在内存中占据 8 个字节空间,也就是 64 个二进制位。

我的电脑有 16GB 的内存空间,也就是一共有 1024 * 1024 * 1024 * 8 这么多的二进制位

(2) 类型其实约定了能对这个变量做什么样的操作

例如 int / float 类型的变量, 可以进行 + - * / 等操作,但int 和float这些不能使用len。

而 str 类型的变量,只能进行 + (并且行为是字符串拼接),不能进行 - * / ,但是还能使用 len 等其他操作。

总结: 类型系统其实是在对变量进行 "归类",相同类型的变量(数据) 往往具有类似的特性和使用规则。

动态类型特性

在 Python 中,一个变量是什么类型,是可以在 "程序运行" 过程中发生变化的,这个特性称为 "动态类型"。

a = 10

print(type( a ))

a = 'hello'

print(type( a ))

a = True

print(type( a ))

在程序执行过程中(是说程序已经跑起来了),a 的类型刚开始是 int,后面变成了 str,再后来变成了布尔类型,a的类型随着程序的运行发生改变,这种特性我们就称之为动态类型。

与动态类型相对的叫做"静态类型"。

静态类型:程序在运行的过程中,变量的类型始终保持不变,这种类型就叫做静态类型。

C++/Java 这样的语言则不允许这样的操作,一个变量定义后类型就是固定的了,这种特性则称为 "静态类型"。

注意:一个编程语言是否是静态类型,只是取决于运行时,类型是否发生改变,不取决于变量定义的时候是否声明类型!

Python作为一个动态类型的语言,在定义变量的时候,也是可以写类型的!

比如:

复制代码
a:int = 10
a:str = 'hello'
a:bool = True 

动态类型特性是一把双刃剑

对于中小型程序,可以大大的解约代码量(比如写一段代码就可以同时支持多种类型),对于大型程序,则提高了模块之间的交互成本,(程序员 A 提供的代码难以被 B 理解)。

注释

注释是什么

注释是一种特殊的代码, 它不会影响到程序的执行, 但是能够起到解释说明的作用, 能够帮助程序猿理解程序代码的执行逻辑。

PS: 写代码是一件比较烧脑的事情,读代码同样也非常烧脑,相比于一板一眼的代码,一些口语化的描述能更好的帮助程序猿理解程序。

计算 4 个数字 67.5, 89.0, 12.9, 32.2 的方差

avg = (67.5 + 89.0 + 12.9 + 32.2) / 4

total = (67.5 - avg) ** 2 + (89.0 - avg) ** 2 + (12.9 - avg) ** 2 + (32.2 - avg) ** 2

result = total / 3

print(result)

形如上述代码,如果没有注释,直接阅读,是不容易 get 到代码的含义是计算方差。但是通过加了一行注释解释一下,就让人一目了然了。

PS: 代码的第一目标是容易理解,第二目标才是执行正确。

写注释不光是为了方便别人来理解,也是方便三个月之后的自己理解。

一个反例:早些年医生的手写处方

注释的语法

Python 中有两种风格的注释。

(1) 注释行

使用 # 开头的行都是注释

#开头的注释,一般是写在要注释的代码的上方,也有少数情况是写在代码的右侧的,很少会写在代码的下方

这是一行注释

(2) 文档字符串

使用三引号引起来的称为 "文档字符串",也可以视为是一种注释。

可以包含多行内容

一般放在 文件/函数/类 的开头

""" 或者 ''' 均可 (等价)
"""

这是文档字符串,起到的作用和注释一样,也是解释说明的效果

"""

文档字符串和我们的#不同,文档字符串可以被我们的Python解释器识别的,然后我们就可以搭配一些工具更方便的看到文档字符串的内容。

什么时候用文档字符串呢?

比如说在公司进行协同开发的时候,你写了一个功能,给被人去用,就可以通过文档字符串来描述这里的功能大概是怎么工作的,同时呢,给别人使用的时候提供一些参考依据。

注释的规范

  1. 内容准确:注释内容要和代码一致,匹配,并在代码修改时及时更新

  2. 篇幅合理:注释既不应该太精简,也不应该长篇大论

  3. 使用中文:一般中国公司都要求使用中文写注释,外企另当别论

  4. 积极向上:注释中不要包含负能量(例如:领导 SB 等)

相关推荐
南宫理的日知录10 分钟前
99、Python并发编程:多线程的问题、临界资源以及同步机制
开发语言·python·学习·编程学习
coberup19 分钟前
django Forbidden (403)错误解决方法
python·django·403错误
逊嘘27 分钟前
【Java语言】抽象类与接口
java·开发语言·jvm
Half-up29 分钟前
C语言心型代码解析
c语言·开发语言
龙哥说跨境1 小时前
如何利用指纹浏览器爬虫绕过Cloudflare的防护?
服务器·网络·python·网络爬虫
Source.Liu1 小时前
【用Rust写CAD】第二章 第四节 函数
开发语言·rust
monkey_meng1 小时前
【Rust中的迭代器】
开发语言·后端·rust
余衫马1 小时前
Rust-Trait 特征编程
开发语言·后端·rust
monkey_meng1 小时前
【Rust中多线程同步机制】
开发语言·redis·后端·rust
Jacob程序员1 小时前
java导出word文件(手绘)
java·开发语言·word