3. 基础语法
3.1 运行 Python
3.1.1 交互式解释器
在命令行窗口执行 python
后,进入 Python 的交互式解释器。exit() 或 Ctrl + D
组合键退出交互式解释器。
3.1.2 命令行脚本
在命令行窗口执行 python script-file.py
,以执行 Python 脚本文件。
3.1.3 指定解释器
如果在 Python 脚本文件首行输入 #!/usr/bin/env python
,那么可以在命令行窗口中执行 /path/to/script-file.py
以执行该脚本文件。
注:该方法不支持 Windows 环境。
3.2 编码
默认情况下,3.x 源码文件都是 UTF-8 编码,字符串都是 Unicode 字符。也可以手动指定文件编码:
# -*- coding: utf-8 -*-
或者
# encoding: utf-8
注意: 该行标注必须位于文件第一行
3.3 标识符
- 第一个字符必须是英文字母或下划线 _ 。
- 标识符的其他的部分由字母、数字和下划线组成。
- 标识符对大小写敏感。
注:从 3.x 开始,非 ASCII 标识符也是允许的,但不建议。
3.4 保留字
保留字即关键字,我们不能把它们用作任何标识符名称。Python 的标准库提供了一个 keyword 模块,可以输出当前版本的所有关键字:
import keyword
print(keyword.kwlist)
输出会类似如下:
[‘False’, ‘None’, ‘True’, ‘and’, ‘as’, ‘assert’, ‘break’, ‘class’, ‘continue’, ‘def’, ‘del’, ‘elif’, ‘else’, ‘except’, ‘finally’, ‘for’, ‘from’, ‘global’, ‘if’, ‘import’, ‘in’, ‘is’, ‘lambda’, ‘nonlocal’, ‘not’, ‘or’, ‘pass’, ‘raise’, ‘return’, ‘try’, ‘while’, ‘with’, ‘yield’]
3.5 注释
单行注释采用#,多行注释采用”’或"""。
# 这是单行注释
'''
这是多行注释
这是多行注释
'''
"""
这也是多行注释
这也是多行注释
"""
3.6 行与缩进
Python 最具特色的就是使用缩进来表示代码块,不需要使用大括号 {}。 缩进的空格数是可变的,但是同一个代码块的语句必须包含相同的缩进空格数。缩进不一致,会导致运行错误。
多行语句
Python 通常是一行写完一条语句,但如果语句很长,我们可以使用反斜杠来实现多行语句。
total = item_one + \
item_two + \
item_three
在 [], {}, 或 () 中的多行语句,不需要使用反斜杠。
3.7 空行
函数之间或类的方法之间用空行分隔,表示一段新的代码的开始。类和函数入口之间也用一行空行分隔,以突出函数入口的开始。
空行与代码缩进不同,空行并不是 Python 语法的一部分。书写时不插入空行,Python 解释器运行也不会出错。但是空行的作用在于分隔两段不同功能或含义的代码,便于日后代码的维护或重构。
记住:空行也是程序代码的一部分。
3.8 等待用户输入
input函数可以实现等待并接收命令行中的用户输入。
content = input(" 请输入点东西并按 Enter 键 ")
print(content)
3.9 同一行写多条语句
Python 可以在同一行中使用多条语句,语句之间使用分号;分割。
import sys; x = 'hello world';
sys.stdout.write(x + ' ')
3.10 多个语句构成代码组
缩进相同的一组语句构成一个代码块,我们称之代码组。
像 if、while、def
和 class
这样的复合语句,首行以关键字开始,以冒号:结束,该行之后的一行或多行代码构成代码组。
我们将首行及后面的代码组称为一个子句(clause)。
3.11 print 输出
print 默认输出是换行的,如果要实现不换行需要在变量末尾加上end=""或别的非换行符字符串:
print('123') # 默认换行
print('123', end = "") # 不换行
3.12 import 与 from…import
在 Python 用 import
或者 from...import
来导入相应的模块。
将整个模块导入,格式为:import module_name
从某个模块中导入某个函数,格式为:from module_name import func1
从某个模块中导入多个函数,格式为:from module_name import func1, func2, func3
将某个模块中的全部函数导入,格式为:from module_name import *