Python基础语法框架笔记
变量
变量声明定义
Python的变量的声明和定义很简单,或者说已经淡化了变量声明和定义的区别,一条语句:
param = value
我觉得这个是Python简单易学的一个最基础体现。区别于C/C++, golang,他们变量声明和定义有严格的区分。Python这么做虽然简单了,但也造成了一定的风险,如果我想要使用之前定义的变量,一不小心手残输错了一个字母,Python语法检查不会检查出来,容易造成Bug,且难于调试发现。
变量的类型
-
数字
param = 1 # 整数 param = -1 param = 1.1 # 浮点数 param = 1e10 # 科学计数法 param = 1+2j # 复数
-
字符串
param = "what"
-
布尔
param = True param = False ''' 代表假值: 1. 常量:None; False 2. 数字:0; 0.0; 0j; Decimal(0); Fraction(0, 1) 3. 空量:""; []; (); {}; set(); range(0) '''
-
集合(列表[],元组(),字典{}, set())
- 注意:
- 元组元素不可修改
- set(),字典是无序的
- 注意:
自定义类型:类(class)
类型转换
函数 | 描述 |
---|---|
int(x [,base]) | 将x转换为一个整数 |
float(x) | 将x转换到一个浮点数 |
complex(real [,imag]) | 创建一个复数 |
str(x) | 将对象 x 转换为字符串 |
repr(x) | 将对象 x 转换为表达式字符串 |
eval(str) | 用来计算在字符串中的有效Python表达式,并返回一个对象 |
tuple(s) | 将序列 s 转换为一个元组 |
list(s) | 将序列 s 转换为一个列表 |
set(s) | 转换为可变集合 |
dict(d) | 创建一个字典。d 必须是一个 (key, value)元组序列。 |
frozenset(s) | 转换为不可变集合 |
chr(x) | 将一个整数转换为一个字符 |
ord(x) | 将一个字符转换为它的整数值 |
hex(x) | 将一个整数转换为一个十六进制字符串 |
oct(x) | 将一个整数转换为一个八进制字符串 |
运算符
- 算术运算符:+ - * / %
- 位运算符:| & ^
- 赋值运算符:=[算术运算符||位运算符]
- 条件运算符:== ; != ; > ; < ; >= ; <= ;
语句
声明语句(赋值语句)
运算语句
-
条件语句
if expr: statements elif expr: statements else: statements
-
循环语句
''' for语句和while语句中的else可又可无,主要是在循环正常执行结束后会执行else中的内容 注意:如果通过break跳出循环,else语句不会执行 ''' # for语句 for x in expr: statements else: statements # while语句 while(expr): statements else: satements
break
continue
pass :空语句,什么都不执行的语句
return
函数
函数定义(函数的声明)
def func_name(param1, param2):
statement
参数(输入)
-
位置参数
def func_name(arg1, arg2): statements '''调用''' func_name("hello", "world")
-
关键字参数
def func_name(arg1, arg2): statements '''调用, 利用关键字参数,就无所谓参数的位置顺序了''' func_name(arg1="hello", arg2="world") func_name(arg2="world", arg1="hello")
-
参数默认值
def func_name(arg1, arg2="world"): statements '''调用, 此处不传入第二个参数的话,arg2就默认是“world”''' func_name("hello")
-
不定长参数
-
结合位置实参
def func_name(arg1, arg2, *args): statements ''' 此处args是个列表 '''
-
结合关键字实参
def func_name(arg1, arg2, **args): statements ''' 此处args是个字典 '''
-
返回值(输出)
- 返回简单类型
- 返回复杂类型:列表,字典等等
类
类的定义
class Classname(parent):
'''构造函数'''
def __init__(self[, param1, param2]): # (1)
self.member1 = value1 # 成员属性
self.member2 = value2
statement
'''成员函数'''
def func_name(self[, param1, param2]): # (2)
statement
成员属性
python的程序员属性都是在构造函数_init_中定义的
成员函数
python的所有类的成员函数中都有self关键字,这个关键字表示该类实例化后这个实例化对象本省有点类似C++中的this关键字
异常
异常语句
try:
statements
except (Exception1[, Exception2[,...ExceptionN]]):
statements
else:
statements
异常类型
异常名称 | 描述 |
---|---|
BaseException | 所有异常的基类 |
SystemExit | 解释器请求退出 |
KeyboardInterrupt | 用户中断执行(通常是输入^C) |
Exception | 常规错误的基类 |
StopIteration | 迭代器没有更多的值 |
GeneratorExit | 生成器(generator)发生异常来通知退出 |
StandardError | 所有的内建标准异常的基类 |
ArithmeticError | 所有数值计算错误的基类 |
FloatingPointError | 浮点计算错误 |
OverflowError | 数值运算超出最大限制 |
ZeroDivisionError | 除(或取模)零 (所有数据类型) |
AssertionError | 断言语句失败 |
AttributeError | 对象没有这个属性 |
EOFError | 没有内建输入,到达EOF 标记 |
EnvironmentError | 操作系统错误的基类 |
IOError | 输入/输出操作失败 |
OSError | 操作系统错误 |
WindowsError | 系统调用失败 |
ImportError | 导入模块/对象失败 |
LookupError | 无效数据查询的基类 |
IndexError | 序列中没有此索引(index) |
KeyError | 映射中没有这个键 |
MemoryError | 内存溢出错误(对于Python 解释器不是致命的) |
NameError | 未声明/初始化对象 (没有属性) |
UnboundLocalError | 访问未初始化的本地变量 |
ReferenceError | 弱引用(Weak reference)试图访问已经垃圾回收了的对象 |
RuntimeError | 一般的运行时错误 |
NotImplementedError | 尚未实现的方法 |
SyntaxError | Python 语法错误 |
IndentationError | 缩进错误 |
TabError | Tab 和空格混用 |
SystemError | 一般的解释器系统错误 |
TypeError | 对类型无效的操作 |
ValueError | 传入无效的参数 |
UnicodeError | Unicode 相关的错误 |
UnicodeDecodeError | Unicode 解码时的错误 |
UnicodeEncodeError | Unicode 编码时错误 |
UnicodeTranslateError | Unicode 转换时错误 |
Warning | 警告的基类 |
DeprecationWarning | 关于被弃用的特征的警告 |
FutureWarning | 关于构造将来语义会有改变的警告 |
OverflowWarning | 旧的关于自动提升为长整型(long)的警告 |
PendingDeprecationWarning | 关于特性将会被废弃的警告 |
RuntimeWarning | 可疑的运行时行为(runtime behavior)的警告 |
SyntaxWarning | 可疑的语法的警告 |
UserWarning | 用户代码生成的警告 |
触发异常
if expr :
raise Exception(arg1 [, arg2])
# Exception: 是个所有异常的基类
# arg1,arg2: 是自已提供的异常参数
'''实例'''
def test_exception(arg):
if arg<1:
raise Exception("Invalid arg")
try:
test_exception(0)
except Exception as err:
print 1, err
else:
print 2
自定义异常
'''定义'''
class Networkerror(RuntimeError):
def __init__(self, arg):
self.args = arg
'''使用'''
try:
raise Networkerror("Bad hostname")
except Networkerror,e:
print e.args