回顾昨天知识
-
表达式
-
字符串
'hello'
-
数字
100
-
运算符
算术运算符
+ - * / // % **
-
比较运算符
< <= > >= == !=
-
布尔运算
and or not
-
条件表达式
左表达式 if 条件表达式 else 右表达式
-
函数
print(...) input(...) int(...) float(...) str(...) bool(...)
-
-
语句
-
赋值语句
a = 100
-
表达式语句
print(a)
-
del 语句
del a
-
pass 语句
if True: pass
-
if 语句(复合语句)
if 条件表达式1: 语句块1 elif 条件表达式2: 语句块2 elif 条件表达式3: 语句块3 elif 条件表达式n: 语句块n else: 语句块other
-
-
运算符的优先级
1 + 3 * 3 ** 2 + 4 // 2 1 + 3 * 9 + 4 // 2 1 + 27 + 4 // 2 1 + 27 + 2 28 + 2 30
运算符优先级表
运算符 | 描述 |
---|---|
(expressions...) ,[expressions...] , {key: value...} , {expressions...}
|
绑定或加圆括号的表达式,列表显示,字典显示,集合显示 |
x[index] , x[index:index] , x(arguments...) , x.attribute
|
抽取,切片,调用,属性引用 |
await x
|
await 表达式 |
** |
乘方 5 |
+x , -x , ~x
|
正,负,按位非 NOT |
* , @ , / , // , %
|
乘,矩阵乘,除,整除,取余 6 |
+ , -
|
加和减 |
<< , >>
|
移位 |
& |
按位与 AND |
^ |
按位异或 XOR |
` | ` |
in , not in , is , is not , < , <= , > , >= , != , ==
|
比较运算,包括成员检测和标识号检测 |
not x
|
布尔逻辑非 NOT |
and |
布尔逻辑与 AND |
or |
布尔逻辑或 OR |
if -- else
|
条件表达式 |
lambda |
lambda 表达式 |
:= |
赋值表达式 |
字符串
-
字面值(前期知识回顾)
'hello' "hello" '''hello''' """hello"""
-
字符串转义
\' 代表一个单个的 ' \n 换行
-
字符串的运算
- 用于拼接字符串
- 用于生成重复的字符串
-
原始字符串(raw 字符串)
字面值格式
r'字符串内容' r"字符串内容" r'''字符串内容''' r"""字符串内容"""
-
in / not in 运算符
-
作用
-
示例
>>> s = 'welcome to beijing!' >>> 'to' in s True >>> 'weimingze' in s False >>> 'beijing' not in s False >>> 'weimz' not in s True
-
-
字符串的索引 index
-
语法
字符串[整数表达式]
-
作用
用来获取字符串其中的一个字符
-
说明
正向索引: 字符串的 正向索引是从0开始的,.... 最后一个索引为 len(s)-1
反向索引: 字符串的反向索引是从 -1 开始的,-1 代表最后一个,... -len(s) 代表第一个
-
示例
>>> s = 'ABCDE' >>> s[1] B >>> s[1+2] D >>> s[-1] E
-
-
练习
-
字符串的切片 slice
-
作用
从字符串序列中取出相应位置的元素,重新组成一个新的字符串
-
语法
-
说明
开始索引b是切片切下的开始位置
结束索引e 是切片的终止位置(但不包含终止点)
-
步长是切片取出数据后向后移动的方向和偏移量
- 没有步长,相当于步长为1(默认为1)
- 当步长为正数时,取正向切片
- 开始索引默认为0, 结束索引是最后一个元素的下一个索引
- 当步长为负数时,取反向切片
- 开始索引默认为-1, 结束索引是第一个元素的前一个索引
-
示例
# 01234 >>> s = 'ABCDE' >>> s[1:] # 'BCDE' >>> s[-2:] # 'DE' >>> s[1:4] # 'BCD' >>> s[:] # 'ABCDE' >>> s[:2] # 'AB' >>> s[1:1] # '' >>> s[4:2] # '' >>> s[::] # 等同于 s[::1] 'ABCDE' >>> s[::2] # 'ACE' >>> s[2::2] # 'CE' >>> s[-1::-2] # 'ECA' >>> s[::-1] # 'EDCBA'
-
-
练习1
-
练习2
字符串的格式化表达式
-
作用
生成具有一定格式的字符串
-
语法规则
占位符和类型码
占位符和类型码 | 说明 |
---|---|
%s | 转成字符串, 使用 str(x) 函数转换(常用) |
%d | 转成 十进制的整数(常用) |
%o | 转成 八进制的整数 |
%x,%X | 转成 十六进制的整数 |
%e,%E | 转成 指数格式的浮点数 |
%f,%F | 转成小数格式的浮点数(常用) |
%g,%G | 转成指数格式或小数格式的浮点数 |
%% | 转成一个% |
-
示例1
>>> fmt = """ 甲方:_____%s_____ 乙方:_____%s_____ ....... 金额:_%d__ """ >>> s = fmt % ("魏眀择", '达内', 10000) >>> print(s) 甲方:_____魏眀择_____ 乙方:_____达内_____ ....... 金额:_10000__
-
示例2
>>> "+++%d+++" % 999 # 返回 '+++999+++' '+++999+++' >>> "+++%s+++" % 3.14 '+++3.14+++' >>> "+++%s+++" % "weimz" '+++weimz+++' >>> "+++%d+++" % 3.1415 '+++3+++' >>> "+++%d+++" % 13 '+++13+++' >>> "+++%o+++" % 13 '+++15+++' >>> "+++%x+++" % 13 '+++d+++' >>> "+++%e+++" % 3.1415 '+++3.141500e+00+++' >>> "+++%f+++" % 3.1415 '+++3.141500+++' >>> "+++%g+++" % 3.1415 '+++3.1415+++' >>> "+++%g+++" % 3141523274812374281342374324.23748123742183472 '+++3.14152e+27+++'
-
占位符和类型码之间的格式化语法
-
示例
>>> "--%d--" % 99 '--99--' >>> "--%5d--" % 99 '-- 99--' >>> "--%05d--" % 99 '--00099--' >>> "--%5d--" % 99 '-- 99--' >>> "--%+5d--" % 99 '-- +99--' >>> "--%-5d--" % 99 '--99 --' >>> "--%f--" % 3.1415926 '--3.141593--' >>> "--%.2f--" % 3.1415926 '--3.14--' >>> "--%7.2f--" % 3.1415926 '-- 3.14--'
-
练习
字符串的常用方法 (method)
-
方法的调用语法
-
示例:
>>> "abc".isalpha() True >>> "123".isalpha() False >>> "123".isdigit() True
- 字符串的常用方法
方法名(S代表字符串对象) 说明 S.isalpha() 判断字符串是否是英文字符 S.isdigit() 判断字符串是否是全为数字 S.isupper() 判断字符串是否是全为大写的英文字符 S.islower() 判断字符串是否是全为小写的英文字符 S.center(width[, fill]) 将字符串按width 宽度居中,左右默认填充空格 S.count(sub[, start[, end]]) 获取字符串中的子串的个数 S.startswith(prefix) 返回S是否以prefix 开头 S.endswith(suffic) 返回S是否以suffic结尾 str.replace(old, new[, count]) 替换字符串 str.find(sub[, start[, end]]) 查找字符串,返回第一次出现的索引,如果没找到,返回-1 str.index(sub[, start[, end]]) 查找字符串,返回第一次出现的索引,如果没找到则报错(从左向右开始找) str.rindex(sub[, start[, end]]) 查找字符串,返回第一次出现的索引,如果没找到则报错(从右向左开始找) -
示例:
>>> s = "ABC" >>> s.center(10) ' ABC ' >>> s.center(10, '#') '###ABC####' >>> s = 'hello world, hello china' >>> s.count('hello') 2 >>> s.count('hello', 10) 1 >>> s.count('hello', 10, 12) 0 >>> s = "/root/music/冰雨.mp3" >>> s.startswith('/root/') True >>> s.endswith('.mp3') True >>> s.endswith('music') False >>> s = 'welcome to Beijing' >>> s.upper() 'WELCOME TO BEIJING' >>> s.lower() 'welcome to beijing' >>> s.title() 'Welcome To Beijing' >>> s = '/root/music/冰雨.mp3' >>> pos = s.rindex('/') >>> pos 11 >>> pathname= s[:pos] >>> filename = s[pos+1:] >>> print(pathname) /root/music
-
练习
-
-
语句回顾
- 表达式语句
- 赋值语句
name = input("xxxx: ")
- pass 语句
- if 语句
-
循环语句
-
种类
- while 语句
- for 语句
-
问题:
# 打印 10 行 hello world print("hello world!")
-
while 语句
-
作用
根据一定的条件,重复的执行某个语句块
语法
-
说明
- else 子句可以省略
- else 子句 当且仅当 真值表达式为假Flase的时候 会执行 else 里的语句块2
- 如果 此 while 是因为 调用 break 语句而终止循环。则 else 子句里的语句不会执行
-
示例1
-
示例2
# 打印 5 行 "hello world" i = 0 while i < 5: print("hello world") i = i + 1 # 也可写成 i += 1 else: print("while 语句已经结束!")
-
练习1
-
练习2
语句嵌套
while 语句也是语句, 和其他的语句一样,可以嵌套到其他的任何复合语句中。
-
while 语句嵌套示意:
-
练习:
break 语句
-
作用
用于循环语句(while, for语句)中, 当break 执行是,她会终止包含他的当前循环
-
说明
- break 语句只能用在 while 语句或for语句的内部.
- break 语句通常和 if 语句组合使用.
- 当break 语句执行后,此循环语句break 之后的所有语句都不会执行(else 子句里的语句也不执行)
- break 语句只能终止包含他的当前循环,当有循环嵌套时,只能跳出离他最近的一个循环
-
示例
i = 1 while i <= 5: print('i=', i) i += 1 else: print('循环结束: i=', i)
-
死循环
- 死循环是指循环条件一直成立的循环
- 死循环通常使用 break 语句来终止循环
- 死循环的 else 子句中的语句永远不会执行
-
写法
-
练习1
课后练习1:
- 课后练习2
- 课后练习3
-
课后练习4
答案
# 已知, 局域网的IP 都是: 192.168.xxx.yyy # xxx 从 0 ~ 10, yyy 从 1 ~ 254 # 写程序,生成 从 192.168.0.1 ~ 192.168.10.254 区间的 2540 个 IP 地址 # # 提示用循环嵌套 xxx = 0 while xxx <= 10: # 此处 xxx =0, 生成 1~254 的数,交给 yyy yyy = 1 while yyy <= 254: # 生成 IP 地址 ip = '192.168.%d.%d' % (xxx, yyy) print(ip) yyy += 1 xxx += 1
课后练习5
答案
# 写一个程序,输入三行文字, 按最长的一行, 打印如下图形方框
# 请输入: hello
# 请输入: welcome to beijing
# 请输入: aaaaaaa
# 打印:
# +--------------------+
# | hello |
# | welcome to beijing |
# | aaaaaaa |
# +--------------------+
# 提示: str.center(width)
s1 = input("请输入:") # ctrl + d 可以复制当前行
s2 = input("请输入:")
s3 = input("请输入:")
len1 = len(s1) # 求取字符串的长度
len2 = len(s2)
len3 = len(s3)
# 从上面三个数中,找出最大的一个, 用 mymax 变量绑定
# 方法2, 通用的算法
mymax = len1
if len2 > mymax:
mymax = len2
if len3 > mymax:
mymax = len3
# 方法1
# if len1 > len2:
# # 让 len1 和 len3 再比较
# if len1 > len3:
# mymax = len1
# else:
# mymax = len3
# else:
# # 让 len2 和 len3 再比较
# if len2 > len3:
# mymax = len2
# else:
# mymax = len3
print('最大长度是:', mymax)
# 计算第一行
line1 = '+' + '-' * (mymax +2) + '+'
print(line1)
# 文字的第一行
# 方法1 , 用 str.center 居中文字的第一行
# center_s1 = '| ' + s1.center(mymax) + ' |'
# 方法2 , 用 自己的方法 居中文字的第一行
left_blanks = (mymax - len1) // 2 # 计算左侧的空格数
right_blanks = mymax - len1 - left_blanks # 计算右侧的空格数
center_s1 = '| ' + ' ' * left_blanks + s1 + ' ' * right_blanks + ' |'
print(center_s1)
# 文字的第二行
center_s2= '| ' + s2.center(mymax) + ' |'
print(center_s2)
# 文字的第三行
center_s3 = '| ' + s3.center(mymax) + ' |'
print(center_s3)
# 打印最后一行
print(line1)