01 Python基础语法-2

2,计算机基础知识

 

  • 艾伦·麦席森·图灵(Alan Mathison Turing,1912年6月23日-1954年6月7日),英国数学家、逻辑学 家,被称为计算机科学之父,人工智能之父。

  • 图灵提出的著名的图灵机模型为现代计算机的逻辑工作方式奠定了基础。

  • 图灵机已经有输入、输出和内部状态变化机制了。

 

冯·诺依曼著名匈牙利裔美籍犹太人数学家、计算机科学家、物理学家和化学家 ,数字计算机之父。他 提出了以二进制作为数字计算机的数制基础,计算机应该按照程序顺序执行,计算机应该有五大部件组 成。

2.1 冯诺依曼体系

 

五大核心部件

  • 中央处理器CPU
    • 运算器:用于完成各种算术运算、逻辑运算和数据传送等数据加工处理。
    • 控制器:用于控制程序的执行,是计算机的大脑。运算器和控制器组成计算机的中央处理器 (CPU)。控制器根据存放在存储器中的指令序列(程序)进行工作,并由一个程序计数器 控制指令的执行。控制器具有判断能力,能根据计算结果选择不同的工作流程。
  • 存储器:用于记忆程序和数据,例如:内存。程序和数据以二进制代码形式不加区别地存放在存储 器中,存放位置由地址确定。内存是掉电易失的设备。
  • 输入设备:用于将数据或程序输入到计算机中,例如:鼠标、键盘。
  • 输出设备:将数据或程序的处理结果展示给用户,例如:显示器、打印机。

CPU中还有寄存器和多级缓存Cache。

  • CPU并不直接从速度很慢的IO设备上直接读取数据,CPU可以从较慢的内存中读取数据到CPU的寄 存器上运算
  • CPU计算的结果也会写入到内存,而不是写入到IO设备上

2.2 计算机语言

语言是人与人沟通的表达方式。

计算机语言是人与计算机之间沟通交互的方式。

2.2.1 机器语言

  • 一定位数的二进制的0和1组成的序列,也称为机器指令
  • 机器指令的集合就是机器语言
  • 与自然语言差异太大,难学、难懂、难写、难记、难查错

2.2.2 汇编语言

  • 用一些助记符号替代机器指令,称为汇编语言。ADD A,B 指的是将寄存器A的数与寄存器B的数相 加得到的数放到寄存器A中
  • 汇编语言写好的程序需要汇编程序转换成机器指令
  • 汇编语言只是稍微好记了些,可以认为就是机器指令对应的助记符。只是符号本身接近自然语言

2.2.3 高级语言

  • 接近自然语言和数学语言的计算机语言
  • 高级语言首先要书写源程序,通过编译程序把源程序转换成机器指令的程序
  • 1954年正式发布的Fortran语言是最早的高级语言,本意是公式翻译
  • 人们只需要关心怎么书写源程序,针对不同机器的编译的事交给编译器关心处理

 

  • 语言越高级,越接近人类的自然语言和数学语言
  • 语言越低级,越能让机器理解
  • 高级语言和低级语言之间需要一个转换的工具:编译器、解释器

2.2.4 编译语言

  • 把源代码转换成目标机器的CPU指令
  • C、C++等语言的源代码需要本地编译

2.2.5 解释语言

  • 解释后转换成字节码,运行在虚拟机上,解释器执行中间代码
  • Java、Python、C#的源代码需要被解释器编译成中间代码(Bytecode),在虚拟机上运行

2.3 高级语言的发展

  • 非结构化语言
  • 编号或标签、GOTO,子程序可以有多个入口和出口 - 有分支、循环
  • 结构化语言
    • 任何基本结构只允许是唯一入口和唯一出口
    • 顺序、分支、循环,废弃GOTO
  • 面向对象语言
    • 更加接近人类认知世界的方式,万事万物抽象成对象,对象间关系抽象成类和继承
    • 封装、继承、多态
  • 函数式语言
    • 古老的编程范式,应用在数学计算、并行处理的场景。引入到了很多现代高级语言中
    • 函数是“一等公民”,高阶函数

2.5 程序Program

  • 算法 + 数据结构 = 程序
  • 数据是一切程序的核心
  • 数据结构是数据在计算机中的类型和组织方式
  • 算法是处理数据的方式,算法有优劣之分

只有选对了合理的数据结构,并采用合适的操作该数据结构的算法,才能写出高性能的程序。

2.6 写程序的难点

  • 理不清数据
  • 搞不清处理方法
  • 无法把数据设计转换成数据结构,无法把处理方法转换成算法
  • 无法用设计范式来进行程序设计

3 python基础

3.1 Python解释器

解释器说明
CPython官方,C语言开发,最广泛的Python解释器
IPython一个交互式、功能增强的CPython
PyPyPython语言写的Python解释器,JIT技术,动态编译Python代码
JythonPython的源代码编译成Java的字节码,跑在JVM上
IronPython与Jython类似,运行在.Net平台上的解释器,Python代码被编译成.Net的字节码
stacklessPython的增强版本解释器,不使用CPython的C的栈,采用微线程概念编程,并发

编程

3.2 基础语法

3.2.1 注释

#井号注释的文本

3.2.2 数字

  • 整数int
    • Python3开始不再区分long、int,long被重命名为int,所以只有int类型了
    • bool类型,有2个值True、False
    • 进制表示:
十进制10
十六进制0x10 
八进制0o10 
二进制0b10
  • 浮点数float
    • 1.2、3.1415、-0.12,1.46e9等价于科学计数法1.46*109
    • 本质上使用了C语言的double类型
  • 复数complex
    • 1+2j或1+2J

3.2.3 字符串

  • 使用 ' " 单双引号引用的字符的序列
  • ''''和""" 单双三引号,可以跨行、可以在其中自由的使用单双引号
  • r前缀:在字符串前面加上r或者R前缀,表示该字符串不做特殊的处理
  • f前缀:3.6版本开始,新增f前缀,格式化字符串

3.2.4 转义序列

  • \ \t \r \n ' "
  • 上面每一个转义字符只代表一个字符,例如\t 显示时占了4个字符位置,但是它是一个字符
  • 前缀r,把里面的所有字符当普通字符对待,则转义字符就不转义了。

转义:让字符不再是它当前的意义,例如\t,t就不是当前意义字符t了,而是被\转成了tab键

3.2.5 缩进

  • 未使用C等语言的花括号,而是采用缩进的方式表示层次关系
  • 约定使用4个空格缩进

3.2.6续行

  • 在行尾使用 \,注意\之后除了紧跟着换行之外不能有其他字符
  • 如果使用各种括号,认为括号内是一个整体,其内部跨行不用 \

3.2.7 标识符

标识符:

  1. 一个名字,用来指代一个值
  2. 只能是字母、下划线和数字
  3. 只能以字母或下划线开头
  4. 不能是python的关键字,例如def、class就不能作为标识符
  5. Python是大小写敏感的

标识符约定:

  • 不允许使用中文,也不建议使用拼音
  • 不要使用歧义单词,例如class_
  • 在python中不要随便使用下划线开头的标识符

3.2.8 常量

  • 一旦赋值就不能改变值的标识符 -
  • python中无法定义常量

3.2.9 字面常量

一个单独的不可变量,例如 12、"abc" 、'2341356514.03e-9'

3.2.10 变量

  • 赋值后,可以改变值的标识符

3.2.11 标识符本质

每一个标识符对应一个具有数据结构的值,但是这个值不方便直接访问,程序员就可以通过其对应的标 识符来访问数据,标识符就是一个指代。一句话,标识符是给程序员编程使用的。

3.2.12 语言类型

 

Python是动态语言、强类型语言。

  • 静态语言

    • 事先声明变量类型,之后变量的值可以改变,但值的类型不能再改变
    • 编译时检查
  • 动态语言

    • 不用事先声明类型,随时可以赋值为其他类型
    • 编程时不知道是什么类型,很难推断
  • 强类型语言

    • 不同类型之间操作,必须先强制类型转换为同一类型。print('a'+1)
  • 弱类型语言

    • 不同类型间可以操作,自动隐式转换,JavaScript中console.log(1+'a') 但是要注意的是,强与弱只是一个相对概念,即使是强类型语言也支持隐式类型转换。

3.3 False等价

 

False等价布尔值,相当于bool(value)

  • 空容器
    • 空集合set
    • 空字典dict
    • 空列表list
    • 空元组tuple
  • 空字符串
  • None
  • 0

3.4 逻辑运算真值表

 

3.4.1 算术运算符

+、-、*、/、//向下取整整除、%取模、**幂

注:在Python2中/和//都是整除。

3.4.2 位运算符

&位与、|位或、^异或、<<左移、>>右移

~按位取反,包括符号位

3.4.3 比较运算符

==、!=、>、>=、<、<=

链式比较: 4 > 3 > 2

比较运算符,返回一个bool值

思考:1 == '1' 吗? 1 > '1' 吗?

3.4.4 逻辑运算符

与and、或or、非not

逻辑运算符也是短路运算符

  • and 如果前面的表达式等价为False,后面就没有必要计算了,这个逻辑表达式最终一定等价为 False
    • 1 and '2' and 0
    • 0 and 'abc' and 1
  • or 如果前面的表达式等价为True,后面没有必要计算了,这个逻辑表达式最终一定等价为True 1 or False or None
  • 特别注意,返回值。返回值不一定是bool型
  • 把最频繁使用的,做最少计算就可以知道结果的条件放到前面,如果它能短路,将大大减少计算量

3.4.5 赋值运算符

  • a = min(3, 5)
  • +=、 -= 、*=、/=、%=、//= 等
  • x = y = z = 10

3.4.6 成员运算符

in、not in

3.4.7 身份运算符

is 、is not

3.5 运算符优先级

 

  • 单目运算符 > 双目运算符
  • 算数运算符 > 位运算符 > 比较运算符 > 逻辑运算符
    • -3 + 2 > 5 and 'a' > 'b'
  • 搞不清楚就使用括号。长表达式,多用括号,易懂、易读

3.6 表达式

由数字、符号、括号、变量等的组合。有算数表达式、逻辑表达式、赋值表达式、lambda表达式等 等。 Python中,赋值即定义。

Python是动态语言,只有赋值才会创建一个变量,并决定了变量的类型和 值。

如果一个变量已经定义,赋值相当于重新定义。

3.7 内建函数

内建函数函数签名说明
printprint(value, ..., sep=' ', 
end='\n')将多个数据输出到控制台,默认使用空格分隔、 \n换行 
inputinput([prompt])在控制台和用户交互,接收用户输入,并返回字 符串
intint(value)将给定的值,转换成整数。int本质是类
strstr(value))将给定的值,转换成字符串。str本质是类
typetype(value)返回对象的类型。本质是元
isinstanceisinstance(obj,class or tuple比较对象的类型,类型可以是obj的基类
print(1,2,3,sep='\n', end='***')

type(1) # 返回的是类型,不是字符串
type('abc') # 返回的是类型,不是字符串
type(int) # 返回type,意思是这个int类型由type构造出来 type(str) # 返回type,也是类型
type(type) # 也是type

print(isinstance(1, int)) print(isinstance(False, int)) # True

3.8 程序控制

  • 顺序
    • 按照先后顺序一条条执行
    • 例如,先洗手,再吃饭,再洗碗
  • 分支
    • 根据不同的情况判断,条件满足执行某条件下的语句
    • 例如,先洗手,如果饭没有做好,玩游戏;如果饭做好了,就吃饭;如果饭都没有做,叫外卖
  • 循环
    • 条件满足就反复执行,不满足就不执行或不再执行
    • 例如,先洗手,看饭好了没有,没有好,一会来看一次是否好了,一会儿来看一次,直到饭 好了,才可是吃饭。这里循环的条件是饭没有好,饭没有好,就循环的来看饭好了没有

3.8.1 单分支

if condition: 
    代码块
if 1<2: # if True:
    print('1 less than 2') # 代码块
  • condition必须是一个bool类型,这个地方有一个隐式转换bool(condition),相当于False等价
  • if 语句这行最后,会有一个冒号,冒号之后如果有多条语句的代码块,需要另起一行,并缩进
    • if、for、def、class等关键字后面都可以跟代码块
    • 这些关键后面,如果有一条语句,也可以跟在这一行后面。例如if 1>2: pass

3.8.2 多分支

if condition1: 
    代码块1
elif condition2: 
    代码块2
elif condition3: 
    代码块3
......
else:
    代码块
a = 5
if a<0: 
    print('negative') elif a==0: # 相当于 a >= 0 
    print('zero')
else: # 相当于 a > 0 
    print('positive')
  • 多分支结构,只要有一个分支被执行,其他分支都不会被执行
  • 前一个条件被测试过,下一个条件相当于隐含着这个条件
# 嵌套 
a = 5 
if a == 0:
    print('zero')
else:
    if a > 0: 
        print('positive') 
    else: 
        print('negative')

3.8.3 while循环

while循环多用于死循环,或者不明确知道循环次数的场景

while cond: 
    block

while True: # 死循环 
    pass

a = 10
while a: # 条件满足则进入循环 
    print(a)
    a -= 1
  • 上例执行结果是什么?
  • 为什么?
  • 会不会打印出0?要注意边界的分析
  • 如果a=-10可以吗?如何改?回忆一下,False等价是什么?

3.8.4 for语句

for element in iteratable: # 可迭代对象中有元素可以迭代,进入循环体 
    block
 
 for i in range(0, 10): 
    print(i)
内建函数函数签名说明
rangerange(stop) range(start, stop[, step])返回惰性的对象可以生成一个序列,遍历它就可以得到这个序列的一个个 元素/前包后不包
# 计数器
for i in range(0): 
    print(i) print('---------')
 
 
 for i in range(-2): 
    print(i) print('---------')
    

for i in range(1): 
    print(i)

range(i),i大于0,相当于计数器。

练习:

  • 打印1到10
  • 打印10以内的奇数
  • 打印10以内的偶数
  • 倒着打印10以内的奇数或偶数
# 打印偶数
for i in range(0, 10): 
    if i % 2 == 0 : 
        print(i)
        
        

for i in range(0, 10, 2): 
    print(i)
    
 
 # 打印奇数
for i in range(0, 10): 
    if i % 2 != 0 : 
        print(i)
        
 for i in range(1, 10, 2): 
    print(i)
    
    
    # 倒着打印
for i in range(8, -1 , -2): 
    print(i)

3.8.5 continue

跳过当前循环的当次循环,继续下一次循环

for i in range(0, 10):
    if i % 2 != 0 : continue 
    print(i)
    
for i in range(10): 
    if i % 2 != 0 : 
        continue
    print(i)
    
 
for i in range(10): 
    if i & 1: continue 
    print(i)

3.8.6 break

结束当前循环

练习:计算1000以内的被7整除的前20个正整数(for循环)

# 计算1000以内的被7整除的前20个正整数
count = 0
for i in range(7, 1000, 7): 
    print(i)
    count += 1
    if count >= 20: 
        print(count) 
        break

总结:

  • continue和break是循环的控制语句,只影响当前循环,包括while、for循环
  • 如果循环嵌套,
  • continue和break也只影响语句所在的那一层循环 continue和break 只影响循环,所以 if cond: break 不是跳出if,而是终止if外的break所在的循环
  • 分支和循环结构可以嵌套使用,可以嵌套多层。

3.8.7 else子句

如果循环正常结束,else子句会被执行,即使是可迭代对象没有什么元素可迭代

for i in range(0): # 可迭代对象没有迭代 
    pass
else:
    print('ok')
    
 for i in range(0,10): 
    break
else:
    print('ok')
    
    
 for i in range(0,10): 
    continue
else:
    print('ok')

有上例可知,一般情况下,循环正常执行,只要当前循环不是被break打断的,就可以执行else子句。 哪怕是range(0)也可以执行else子句。

3.8.8 三元表达式

在Python中,也有类似C语言的三目运算符构成的表达式,但python中的三元表达式不支持复杂的语句

真值表达式 if 条件表达式 else 假值表达式

三元表达式比较适合简化非常简单的if-else语句。

# 判断用户的输入的值,如果为空,输出"empty",否则输出该值
value = input('>>>') if value: 
    print(value) else: 
    print('empty')
    
 value = input('>>>')
print(value if value else 'empty')

3.8.9 字符串拼接

str(1) + ',' + 'b' # 都转换成字符串拼接到一起 
"{}-{}".format(1, 'a') # {}就是填的空,有2个,就使用2个值填充


# 在3.6后,可以使用插值
a = 100;
b = 'abc'
f'{a}-{b}' # 一定要使用f前缀,在大括号中使用变量名
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值