目录
交互
vscode进入和退出python交互式模式
进入-在终端输入python
退出-在终端输入quit()
注释
# 单行注释
'''
多行注释
'''
"""
多行注释
"""
续行符
但在 [], {}, 或 () 中的多行语句,不需要使用反斜杠 \
total = item_one + \
item_two + \
item_three
输入 输出
str(): 函数返回一个用户易读的表达形式。
repr(): 产生一个解释器易读的表达形式。
x = "a"
input("123") # 按下 enter 键后退出。
print( x, end=" ") # 不换行输出x
>>> s = 'Hello, Runoob'
>>> str(s)
'Hello, Runoob'
>>> repr(s)
"'Hello, Runoob'"
文件
pickle 模块
import 导入模块
将整个模块(somemodule)导入,import somemodule
从某个模块中导入某个函数,from somemodule import somefunction
从某个模块中导入多个函数,from somemodule import firstfunc, secondfunc, thirdfunc
将某个模块中的全部函数导入,from somemodule import *
同一个目录建 fibo.py
另一个py中 import fibo
__name__属性
一个模块被另一个程序第一次引入时,其主程序将运行。如果我们想在模块被引入时,模块中的某一程序块不执行,我们可以用__name__属性来使该程序块仅在该模块自身运行时执行。
dir() 函数:内置的函数 dir() 可以找到模块内定义的所有名称。以一个字符串列表的形式返回:
包
包是一种管理 Python 模块命名空间的形式,采用"点模块名称"。
比如一个模块的名称是 A.B, 那么他表示一个包 A中的子模块 B 。
命令行参数
例 $ python -h
查看各参数帮助信息
运算符
算术运算符:**
幂 /
除,保留小数 //
除,取整
比较(关系)运算符
赋值运算符
逻辑运算符
位运算符
成员运算符
身份运算符
字符串运算符、元组运算符
运算符优先级:not 高于 and 高于 no
数学函数
数学函数
随机数函数
三角函数
数学常量:pi 、e
global 和 nonlocal关键字
global 和 nonlocal关键字
如果要修改嵌套作用域(enclosing 作用域,外层非全局作用域)中的变量则需要 nonlocal 关键字了
基本数据类型
- Python 中变量不需要声明。但在使用前都必须赋值,变量赋值以后该变量才会被创建。一个变量可以通过赋值指向不同类型的对象
- Python 中允许同时为多个变量赋值
- del语句删除单个或多个对象。 例
del var_a, var_b
- 查询变量所指的对象类型:
type()
不会认为子类是一种父类类型isinstance()
会认为子类是一种父类类型
a = b = c = 1
a, b, c = 1, 2, "runoob"
a, b, c, d = 20, 5.5, True, 4+3j
print(type(a), type(b), type(c), type(d))
print(isinstance(a, int))
#输出
<class 'int'> <class 'float'> <class 'bool'> <class 'complex'>
True
Python3 的六个标准数据类型:string、list 和 tuple 都属于 sequence(序列)
- Number(数字):不可变数据
- int
- float
- bool
- complex(复数)例
4+3j
- Sequence(序列):
- Range(范围):不可变数据,例
range(1,10,2)
- String(字符串):不可变数据,例
str = 'abcd'
- Tuple(元组) :不可变数据,例
tuple = ( 'abcd', 2.23, 'runoob', 70.2 )
- List(列表): 可变数据,例
list = [ 'abcd', 786 , 2.23, 'runoob', 70.2 ]
- Set(集合):可变数据,例
sites = {'f', 'g', 'e', 'e'}
或sites = set('abcdee')
- Dictionary(字典):可变数据,例
dict = {'name': 'run', 'code':1, 'site': 'www'}
或dict(...键值对...)
- Range(范围):不可变数据,例
Number 数字
Python3 支持 int、float、bool、complex(复数)。
Python3 只有一种整数类型 int 长整型,没有 python2 中的 Long。
Python3 中 bool 是 int 的子类,True 和 False 可以和数字相加
>>> issubclass(bool, int) # True
>>> True==1 # True
>>> False==0 # True
>>> True+1 # 2
>>> False+1 # 1
>>> 1 is True # False
>>> 0 is False # False
运算:在混合计算时,Python会把整型转换成为浮点数
>>> 5 + 4 # 加法 9
>>> 4.3 - 2 # 减法 2.3
>>> 3 * 7 # 乘法 21
>>> 2 / 4 # 除法,得到一个浮点数 0.5
>>> 2 // 4 # 除法,得到一个整数 0
>>> 17 % 3 # 取余 2
>>> 2 ** 5 # 乘方 32
String 字符串
Python 中的字符串有两种索引方式,从左往右以 0 开始,从右往左以 -1 开始。
str='abcdefg'
# 冒号左边的包括,冒号右边的不包括
print(str[0:-1]) # 输出第一个到倒数第二个的所有字符
print(str[2:5]) # 输出从第三个开始到第五个的字符
print(str[2:]) # 输出从第三个开始的后的所有字符
print (str * 2) # 输出字符串两次,也可以写成 print (2 * str)
反斜杠 \
转义特殊字符,不想让反斜杠发生转义,可以在字符串前面添加一个 r,表示原始字符串
>>> print('Ru\noob')
Ru
oob
>>> print(r'Ru\noob')
Ru\noob
>>>
转义字符
字符串格式化
f-string
f-string 格式化字符串以 f 开头,后面跟着字符串,字符串中的表达式用大括号 {} 包起来,它会将变量或表达式计算后的值替换进去
字符串内建函数
Tuple 元组
可以把字符串看作一种特殊的元组。
虽然tuple的元素不可改变,但它可以包含可变的对象,比如list列表
tup1 = () # 空元组
tup2 = (20,) # 一个元素,需要在元素后添加逗号
tuple = ( 'abcd', 786 , 2.23, 'runoob', 70.2 )
tinytuple = (123, 'runoob')
print (tuple) # 输出完整元组
print (tuple[0]) # 输出元组的第一个元素
print (tuple[1:3]) # 输出从第二个元素开始到第三个元素
print (tuple[2:]) # 输出从第三个元素开始的所有元素
print (tinytuple * 2) # 输出两次元组
print (tuple + tinytuple) # 连接元组
元组内置函数
List 列表
list = [ 'abcd', 786 , 2.23, 'runoob', 70.2 ]
tinylist = [123, 'runoob']
print (list) # 输出完整列表
print (list[0]) # 输出列表第一个元素
print (list[1:3]) # 从第二个开始输出到第三个元素
print (list[2:]) # 输出从第三个元素开始的所有元素
print (tinylist * 2) # 输出两次列表
print (list + tinylist) # 连接列表
Python中,列表与字符串不一样的是,列表中的元素是可以改变的
>>> a = [1, 2, 3, 4, 5, 6]
>>> a[0] = 9
>>> a[2:5] = [13, 14, 15]
>>> a
[9, 2, 13, 14, 15, 6]
>>> a[2:5] = [] # 将对应的元素值设置为 []
>>> a
[9, 2, 6]
Python 列表截取可以接收第三个参数,参数作用是截取的步长,以下实例在索引 1 到索引 4 的位置并设置为步长为 2(间隔一个位置)来截取字符串:
list=['a', 'b', 'c', 'd', 'e', 'f']
print(list[1:4:2]) # ['b', 'd']
print(list[-1:1:-2]) # ['f', 'd']
嵌套列表
使用嵌套列表即在列表里创建其它列表,例如:
>>>a = ['a', 'b', 'c']
>>> n = [1, 2, 3]
>>> x = [a, n]
>>> x
[['a', 'b', 'c'], [1, 2, 3]]
>>> x[0]
['a', 'b', 'c']
>>> x[0][1]
'b'
列表函数&方法
将列表当做堆栈使用
append() 方法可以把一个元素添加到堆栈顶。
用不指定索引的 pop() 方法可以把一个元素从堆栈顶释放出来。
将列表当作队列使用
Set 集合
基本功能是进行成员关系测试和删除重复元素
创建非空集合:set()
或{...}
创建空集合:set()
sites1 = {'a', 'b', 'c', 'd', 'e', 'e'}
sites2 = {'f', 'g', 'h', 'd', 'e', 'e'}
sites3 = {'abcdee'}
sites4 = set('12')
sites5 = set()
print(sites1) # {'d', 'e', 'a', 'b', 'c'}
print(sites2) # {'e', 'f', 'd', 'g', 'h'}
print(sites3) # {'abcdee'}
print(sites4) # {'1', '2'}
print(sites5) # set()
print(sites1 - sites2) # 差集 {'a', 'b', 'c'}
print(sites1 | sites2) # 并集 {'d', 'a', 'g', 'h', 'c', 'e', 'f', 'b'}
print(sites1 & sites2) # 交集 {'d', 'e'}
print(sites1 ^ sites2) # 不同时存在的元素 {'f', 'g', 'b', 'h', 'c', 'a'}
集合的基本操作
集合内置方法
Dictionary 字典
字典当中的元素是通过键来存取的,而不是通过偏移存取。
key
不可变,唯一,可以用数字,字符串或元组充当,而用列表就不行
构造函数 dict() 可以直接从键值对序列中构建字典
dict = {}
dict['one'] = "1 - 菜鸟教程"
dict[2] = "2 - 菜鸟工具"
tinydict = {'name': 'runoob','code':1, 'site': 'www.runoob.com'}
print (dict['one']) # 输出键为 'one' 的值
print (dict[2]) # 输出键为 2 的值
print (tinydict) # 输出完整的字典
print (tinydict.keys()) # 输出所有键
print (tinydict.values()) # 输出所有值
# 结果
1 - 菜鸟教程
2 - 菜鸟工具
{'name': 'runoob', 'code': 1, 'site': 'www.runoob.com'}
dict_keys(['name', 'code', 'site'])
dict_values(['runoob', 1, 'www.runoob.com'])
>>> dict([('Runoob', 1), ('Google', 2), ('Taobao', 3)])
{'Runoob': 1, 'Google': 2, 'Taobao': 3}
>>> {x: x**2 for x in (2, 4, 6)}
{2: 4, 4: 16, 6: 36}
>>> dict(Runoob=1, Google=2, Taobao=3)
{'Runoob': 1, 'Google': 2, 'Taobao': 3}
字典内置函数&方法
遍历技巧
Range 范围
x = range(1,10,2)
print(x) # range(1, 10, 2)
print(type(x)) # <class 'range'>
print(x[0],x[1],x[2],x[3],x[4]) # 1 3 5 7 9
数据类型转换
一般只需要将数据类型作为函数名即可。
隐式类型转换 - 自动完成
显式类型转换 - 需要使用类型函数来转换
推导式
- 元组(tuple)推导式:
(表达式 for 变量 in 序列 if 条件 )
- 列表(list)推导式:
[表达式 for 变量 in 序列 if 条件]
- 集合(set)推导式:
{ 表达式 for 变量 in 序列 if 条件 }
- 字典(dict)推导式:
{ key的表达式: value的表达式 for 变量 in 序列 if 条件 }
变量:自己另取的变量名
序列:已知给出的
条件:可有可无,提供的序列中满足if条件的
表达式:关于变量的变化(变成大写、平方等等)
key的表达式:这个关于变量的变化作为key
value的表达式:这个关于变量的变化作为value
str = 'abcd'
tuple = ( 'abcd', 'runoob')
list = [ 'abcd', 'runoob']
ran = range(1,10,2)
sites = {'f', 'g', 'e', 'e'}
dict = {'name': 'run', 'code':1, 'site': 'www'}
x1 = [name.upper() for name in str]
x2 = [name.upper() for name in tuple]
x3 = [name.upper() for name in list]
x4 = [name for name in ran]
x5 = [name.upper() for name in sites]
x6 = [name.upper() for name in dict]
print(x1, x2, x3, x4, x5, x6)
print(type(x1), type(x2), type(x3), type(x4), type(x5), type(x6))
# 结果
['A', 'B', 'C', 'D'] ['ABCD', 'RUNOOB'] ['ABCD', 'RUNOOB'] [1, 3, 5, 7, 9] ['G',
'E', 'F'] ['NAME', 'CODE', 'SITE']
<class 'list'> <class 'list'> <class 'list'> <class 'list'> <class 'list'> <class 'list'>
条件语句
if condition_1:
statement_block_1
elif condition_2:
statement_block_2
else:
statement_block_3
循环语句
while expr:
statement(s)
if var == 5:
break # 退出整个循序
if var == 3:
continue # 退出本次循环
if letter == 'o':
pass # 空语句,不做任何事情,一般用做占位语句,为了保持程序结构的完整性
print ('执行 pass 块')
else:
additional_statement(s)
for variable in sequence:
statements
else:
statements
简单语句组:while循环体中只有一条语句,你可以将该语句与while写在同一行中
flag = 1
while (flag): print ('欢迎访问菜鸟教程!')
print ("Good bye!")
无限循环:通过设置条件表达式永远不为 false 来实现无限循环
CTRL+C 退出当前的无限循环。无限循环在服务器上客户端的实时请求非常有用。
var = 1
while var == 1 : # 表达式永远为 true
num = int(input("输入一个数字 :"))
print ("你输入的数字是: ", num)
print ("Good bye!")
# 结果
输入一个数字 :5
你输入的数字是: 5
输入一个数字 :
迭代器
iter() 和 next()
迭代器对象可以使用常规for语句进行遍历:for x in iter(list)
StopIteration 异常用于标识迭代的完成,防止出现无限循环的情况,在 next() 方法中我们可以设置在完成指定循环次数后触发 StopIteration 异常来结束迭代。
>>> list=[1,2,3,4]
>>> it = iter(list) # 创建迭代器对象
>>> print (next(it)) # 输出迭代器的下一个元素
1
>>> print (next(it))
2
>>>
class MyNumbers:
def __iter__(self):
self.a = 1
return self
def __next__(self):
if self.a <= 20:
x = self.a
self.a += 1
return x
else:
raise StopIteration
myclass = MyNumbers()
myiter = iter(myclass)
for x in myiter:
print(x)
生成器
在 Python 中,使用了 yield 的函数被称为生成器(generator)。
生成器是一个返回迭代器的函数,只能用于迭代操作,更简单点理解生成器就是一个迭代器。
在调用生成器运行的过程中,每次遇到 yield 时函数会暂停并保存当前所有的运行信息,返回 yield 的值, 并在下一次执行 next() 方法时从当前位置继续运行。
函数
def 函数名(参数列表):
函数体
加了星号 *
的参数会以元组(tuple)的形式导入
声明函数时,参数中星号 *
可以单独出现
如果单独出现星号 *
后的参数必须用关键字传入
加了两个星号 **
的参数会以字典的形式导入
函数形参语法 /
用来指明函数形参必须使用指定位置参数
匿名函数:lambda [arg1 [,arg2,.....argn]]:expression
类
class ClassName:
<statement-1>
.
.
.
<statement-N>
init() 的特殊方法(构造方法)
self代表类的实例,而非类
类的方法与普通的函数只有一个特别的区别——它们必须有一个额外的第一个参数名称, 按照惯例它的名称是 self。
继承
class DerivedClassName(BaseClassName):
<statement-1>
.
.
.
<statement-N>
多继承
Python同样有限的支持多继承形式。多继承的类定义形如下例:
class DerivedClassName(Base1, Base2, Base3):
<statement-1>
.
.
.
<statement-N>
方法重写
如果你的父类方法的功能不能满足你的需求,你可以在子类重写你父类的方法,
类属性与方法
类的私有属性
__private_attrs:两个下划线开头,声明该属性为私有,不能在类的外部被使用或直接访问。在类内部的方法中使用时 self.__private_attrs。
类的方法
在类的内部,使用 def 关键字来定义一个方法,与一般函数定义不同,类方法必须包含参数 self,且为第一个参数,self 代表的是类的实例。
self 的名字并不是规定死的,也可以使用 this,但是最好还是按照约定使用 self。
类的私有方法
__private_method:两个下划线开头,声明该方法为私有方法,只能在类的内部调用 ,不能在类的外部调用。self.__private_methods。
类的专有方法
运算符重载