Python 基础语法

交互

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(...键值对...)
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。
类的专有方法
运算符重载

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值