目录:
1.python基本操作
基本操作注意事项:
PEP8 编码规范
2.python基本数据类型
变量:
变量命名规则:
A
和小写的a
是两个不同的变量)数字:
int_a = 1
print(int_a)
print(type(int_a))
float_a = 1.0
print(float_a)
print(type(float_a))
布尔:
bool_a = True
print(bool_a)
print(type(bool_a))
bool_b = False
print(bool_b)
print(type(bool_b))
字符串:
\
转义符r
忽略转义符的作业+
多个字符串连接# `\` 转义符
str_a = "adb\\n123456"
print(str_a)
# `r` 忽略转义符的作业
str_b = r"adb\n123456"
print(str_b)
# `+` 多个字符串连接
str_c = str_a + str_b
print(str_c)
字符串(索引+切片):
字符串:“abcdefg”
索引: 0123456
切片: start: stop: step
str_d = "abcdefg"
print(str_d[0])
# x>=1
print(str_d[1:])
# 前闭后开原则,1<=x<5
print(str_d[1:5])
# 步长,
print(str_d[1:5:2])
print(str_d[1::2])
列表(List):
var_list = [1, 2, 3, 4, 5, "a", "b", "c", True]
print(var_list)
print(var_list[0])
print(var_list[-1])
print(var_list[2:-2])
print(var_list[2::2])
3.python字符串基本操作
字符串操作的使用场景:
字符串的定义:
# 单行
str_a = "this is a str"
print(str_a)
# 多行
str_b = """
这是一段字符串
hello workld
"""
print(str_b)
字符串常用特殊字符:
# 换行
print("hello \n world")
# 转义
print("hello \\n world")
字符串格式化符号:
符号 | 描述 |
---|---|
%c | 格式化字符及其ASCII码 |
%s | 格式化字符串 |
%d | 格式化整数 |
%u | 格式化无符号整型 |
%o | 格式化无符号八进制数 |
%x | 格式化无符号十六进制数 |
%X | 格式化无符号十六进制数(大写) |
%f | 格式化浮点数字,可指定小数点后的精度 |
%e | 用科学计数法格式化浮点数 |
%p | 用十六进制数格式化变量的地址 |
# world替换掉 %s 的位置
print("hello %s" % "world")
字符串之字面量插值:
# 不设置指定位置,按默认顺序
print("{} {}".format("hello", "world"))
# 设置指定位置
print("{1} {0}".format("hello", "world"))
# 通过名称传递变量
print("{name}hello".format(name="world"))
字符串之字面量插值:
name = "Bob"
school = "hdc"
# 通过 f"{变量名}"
print(f"我的名字叫做{name}, 毕业于{school}")
字符串常用API之join:
a = ["h", "e", "l", "l", "o"]
# 将列表中的每一个元素拼接起来
print("".join(a))
print("|".join(a))
字符串常用API之split:
# 根据split内的内容将字符串进行切分
b="hello world"
print(b.split(" "))
字符串常用API之replace:
# 将原字符串中的 world 替换为 tom
print("hello world".replace("world", "tom"))
字符串常用API之strip:
print(" hello world ".strip())
4.python的运算符
运算符的作用
算数运算符:
+ | 加 |
- | 减 |
* | 乘 |
/ | 除 |
% | 取模 |
** | 幂 |
// | 取整除 |
# 加
a = 1 + 1
print(a)
# 减
b = 2 - 1
print(b)
# 变量之间也可以做运算
c = 4
d = 3
e = c - d
print(e)
# 乘
f = 1 * 2
print(f)
# 除
g = 3 / 2
print(g)
# 取模(取余)
h = 5 % 2
print(h)
# 幂
i = 2 ** 3
print(i)
# 取整除
j = 3 // 2
print(j)
比较运算符:
== | 等于 |
!= | 不等于 |
> | 大于 |
< | 小于 |
>= | 大于等于 |
<= | 小于等于 |
a = 1
b = 2
print(a == b)
print(a != b)
print(a > b)
print(a < b)
print(a <= b)
print(a >= b)
赋值运算符:
= | 简单赋值运算符 |
+= | 加法赋值运算符 |
-= | 减法赋值运算符 |
*= | 乘法赋值运算符 |
/= | 除法赋值运算符 |
%= | 取模赋值运算符 |
**= | 幂赋值运算符 |
//= | 取整赋值运算符 |
# 简单赋值
a = 1
print(a)
# 多个变量赋值
a, b = 1, 2
print(a)
print(b)
# 加法运算
a = a + 1
print(a)
# 加法赋值运算
a += 1
print(a)
逻辑运算符:
运算符 | 逻辑表达式 | 描述 |
and | x and y | x、y 都为真才为真,有一个为假即为假 |
or | x or y | x、y 有一个为真即为真,都为假为假 |
not | not x | 如果 x 为假,则 not x 为真 |
a, b = True, False
print(a and b)
print(a or b)
print(not a)
print(not b)
成员运算符:
运算符 | 描述 |
in | 如果在指定的序列中找到值返回 True,否则返回 False。 |
not in | 如果在指定的序列中没有找到值返回 True,否则返回 False。 |
list_a = ["a", "b", "c"]
str_a = "abcde"
str_b = "bcde"
print("a" in list_a)
print("a" not in list_a)
print("a" in str_a)
print("a" not in str_a)
print("a" in str_b)
身份运算符:
运算符 | 描述 |
is | is 是判断两个标识符是不是引用自一个对象 |
is not | is not 是判断两个标识符是不是引用自不同对象 |
list_a = ["a", "b", "c"]
list_b = ["a", "b", "c"]
# 使用id查看变量的内存地址
print(id(list_a))
print(id(list_b))
print(list_a is list_b)
print(list_a == list_b)
5.python控制流-判断
什么是分支判断?
if 条件判断:
bob = "teacher"
if bob == "teacher":
print("老师")
else 判断语句:
bob = "student"
if bob == "teacher":
print("老师")
else:
print("student")
elif 多重条件:
food = "apple"
if food == "apple":
print("苹果")
elif food == "orange":
print("橘子")
elif food == "banana":
print("香蕉")
else:
print("fruit")
分支嵌套:
my_list = [1, 2, 3, 4, 5]
if my_list:
print("my_list 不为空")
if my_list[0] == 3:
print("my_list 中的第一个元素为 3")
else:
print("my_list 中的第一个元素不是 3")
else:
print("my_list 为空")
三目运算符:
# 正常的赋值操作和判断语句结合
a, b = 1, 2
if a > b:
h = "变量1"
else:
h = "变量2"
# 优化之后更简洁的写法
a, b = 1, 2;
h = "变量1" if a > b else "变量2"
print(h)
6.python控制流-循环
什么是循环:
循环的作用:
for-in循环:
range
函数
# 使用for 循环遍历列表中的元素
for i in [1, 2, 3]:
print(i)
# for 循环结合 range函数
for i in range(1, 100, 2):
print(i)
while 循环:
count = 0
# while循环条件,满足条件执行循环体内代码
while count < 5:
# count 变量+1,否则会进入死循环
print(count)
count += 1
continue:跳出当前轮次循环:
count = 0
while count < 5:
print(count)
if count == 3:
count += 1.5
continue
count += 1
list_demo = [1, 2, 3, 4, 5, 6]
# 循环遍历列表
for i in list_demo:
# 如果i 等于3,那么跳出当前这轮循环,不会再打印3
if i == 3:
continue
print(i)
pass:
print("hdc")
pass
print("school")
练习:
# 使用分支结构实现1~100之间的偶数求和
sum = 0
for i in range(1, 101):
if i % 2 == 0:
sum += i
print(sum)
# 不使用分支结构实现1~100之间的偶数求和
sum = 0
for i in range(0, 101, 2):
sum += i
print(sum)
# 不使用分支结构实现1~100之间的奇数求和
sum = 0
for i in range(1, 101, 2):
sum += i
print(sum)
# 使用while语句实现1~100之间的奇数求和
i, sum = 1, 0
while i < 101:
if i % 2 == 1:
sum += i
i += 1
print(sum)
import random
# 生成随机数
number = random.randint(1, 100)
# 初始化猜测次数和最大猜测次数
guesses = 0
max_guesses = 10
# 提示用户开始猜测
print("我在想一个介于1到100之间的数字。你能猜出它是什么吗?")
# 循环猜测,直到用户猜对或猜测次数用尽
while guesses < max_guesses:
# 提示用户输入猜测的数字
guess = int(input("输入你的猜测: "))
guesses += 1
# 判断猜测是否正确
if guess == number:
print("恭喜你!你猜对了号码一共猜了", guesses, "次.")
break
elif guess < number:
print("你猜测的数字太小了.")
else:
print("你猜测的数字太大了.")
7.python常用数据结构-列表
列表定义:
列表是有序的可变元素的集合,使用中括号[]
包围,元素之间用逗号分隔
列表是动态的,可以随时扩展和收缩
列表是异构的,可以同时存放不同类型的对象
列表中允许出现重复元素
列表使用:创建:
# 1、通过构造函数创建
li1 = list() # 空列表
li2 = list('hello') # 字符串
li3 = list((1, 2, 3)) # 元组
li4 = list({4, 5, 6}) # 集合
li5 = list({'a': 7, 'b': 8}) # 字典
print(type(li1), li1)
print(type(li2), li2)
print(type(li3), li3)
print(type(li4), li4)
print(type(li5), li5)
# 2、中括号创建并填充元素
li6 = [] # 空列表
li7 = [1, 2, 3] # 直接填充对象
print(type(li6), li6)
print(type(li7), li7)
列表使用:索引
li = [1, 2, 3, 4, 5]
# 1、正向索引
print(li[0]) # 打印1
print(li[3]) # 打印4
# 2、反向索引
li = [1, 2, 3, 4, 5]
print(li[-1]) # 打印 5
列表使用:切片
切片 [start: stop: step]
# 切片基本用法
li = ['h', 'e', 'l', 'l', 'o', 'w', 'o', 'r', 'l', 'd']
print(li[0:5:2])
print(li[2:4])
print(li[:4])
print(li[2:])
print(li[::2])
print(li[::-1])
列表使用:运算符:
*
运算符可以重复生成列表元素。+
加号运算符,可以将两个列表合二为一。# 1、重复
li = [1] * 5
print(li) # 打印[1, 1, 1, 1, 1]
# 2、合并
li1 = [1, 2, 3]
li2 = [99, 100]
print(li1 + li2) # 打印[1, 2, 3, 99, 100]
列表使用:成员检测:
in:检查一个对象是否在列表中,如果在则返回 True,否则返回 False。
not in:检查一个列表是否不包含某个元素。如果不在返回 True,否则返回 False。
li = [1, 2, 3]
# in
print(1 in li) # 返回True
print(100 in li) # 返回False
# not in
print(1 not in li) # 返回False
print(100 not in li) # 返回True
列表方法
列表方法 append():
append(item)
:将一个对象 item 添加到列表的末尾。
入参:对象 item
返回:None
# 添加元素
li = []
li.append(1)
li.append(3.14)
li.append("hello world")
li.append([6, 6, 6])
li.append((1.2, 1.5))
li.append({'msg': "Hello"})
print(li) # 打印列表
print(len(li)) # 获取列表元素个数
列表方法 extend()
# extend()的用法
li = []
li.extend('helloworld') # 添加的是字符串的所有字母
li.extend([1, 2, 3]) # 接收列表的所有元素
li.extend((4, 5, 6)) # 接收元组的所有元素
li.extend({'a': 1, 'b': 2}) # 接收字典的所有key值
print(li)
列表方法 insert()
insert(index, item)
:将一个对象插入到指定的索引位置
入参:索引值 index ,一个对象 item
返回:None
原索引位置及后面的元素后移一位
li = [0, 1, 2]
print("插入前: ", li) # 打印 [0, 1, 2]
# 在索引0的位置插入元素
li.insert(0, 'hello world')
print("插入后: ", li) # 打印 ['hello world', 0, 1, 2]
列表方法 pop()
pop(index) 或 pop()
弹出并返回所指定索引的元素。
入参:索引值 index,可不传
返回:指定索引的元素
返回:未指定索引则返回末尾元素
如果索引值不正确,或者列表已经为空,则引发 IndexError 错误
letters = ['h', 'e', 'l', 'l', 'o', 'w', 'o', 'r', 'l', 'd']
print(letters)
n1 = letters.pop(3)
print(n1)
print(letters)
# 不传参数,默认弹出末尾元素
n2 = letters.pop()
print(n2)
print(letters)
列表方法 remove()
remove(item)
移除列表中第一个等于 item 的元素
入参:指定元素 item
返回:None
目标元素必须已存在,否则会报 ValueError
li = ['h', 'e', 'l', 'l', 'o', 'w', 'o', 'r', 'l', 'd']
print(len(li))
# 1、删除指定元素'h'
li.remove('h')
print(li)
print(len(li))
# 2、移除第一个2
li = [1, 2, 3, 2, 1]
li.remove(2)
print(li) # 打印 [1, 3, 2, 1]
# 3、删除不存在的元素,会报ValueError错误
li = [1, 2, 3]
li.remove(100)
列表方法 sort()
sort(key=None, reverse=False)
对列表进行原地排序,只使用 < 来进行各项间比较。
入参:支持 2 个关键字参数:
key
:指定带有一个参数的函数,用于从每个列表元素中提取比较键。reverse
:默认值为 False 表示升序,为 True 表示降序返回:None
nums = [2, 4, 3, 1, 5]
# 1、不传参数,默认升序,数字从小到大排列
nums.sort()
print(nums) # 打印 [1, 2, 3, 4, 5]
# 2、指定key=len,按元素的长度排序
words = ['Python', 'Java', 'R', 'Go']
words.sort(key=len,reverse=False)
print(words)
words.sort(key=len,reverse=True)
print(words)
# 3、指定reverse=True,降序
nums = [2, 4, 3, 1, 5]
nums.sort(reverse=True)
print(nums) # 打印 [5, 4, 3, 2, 1]
列表方法 reverse()
reverse()
:将列表中的元素顺序反转# 反转顺序
nums = [8, 1, 5, 2, 77]
nums.reverse()
print(nums) # 打印[77, 2, 5, 1, 8]
列表嵌套
# 1、创建嵌套列表
li_2d = [['a', 'b', 'c'], [1, 2, 3]]
print(type(li_2d)) # 打印
print(len(li_2d)) # 打印 2
# 2、访问嵌套列表中的元素
print(li_2d[0][2]) # 打印 'c'
print(li_2d[1][0])
列表推导式:
# 实例:将1-10中的所有偶数平方后组成新的列表
# 1、传统解决方案
result = []
for ele in range(1, 11):
if ele % 2 == 0:
result.append(ele ** 2)
print(result)
# 2、使用列表推导式
result = [ele ** 2 for ele in range(1, 11) if ele % 2 == 0]
print(result)
8.python常用数据结构-元组
元组定义:
元组使用:创建:
# 1、直接使用逗号分隔
t5 = 1, 2, 3
print(type(t5))
# 2、通过小括号填充元素
t3 = (1, 2, 3)
print(t3)
print(type(t3))
t4 = ('a', 'b', 'c')
print(t4)
print(type(t4))
# 3、通过构造函数tuple()
t1 = tuple()
print(type(t1))
t2 = tuple([1, 2, 3])
print(t2)
print(type(t2))
元组使用:索引
索引
可以通过索引值来访问对应的元素。
t = tuple(range(1, 6))
print(t)
# 正向索引
print(t[2])
# 反向索引
print(t[-1])
元组使用:切片
切片 [start: stop: step]
# 切片的使用
t = (1, 2, 3, 4, 5, 6)
print(t[:])
print(t[:-2])
print(t[2:4])
print(t[2:5:2])
# 特殊的切片写法:逆序
print(t[::-1])
元组常用方法
元组常用方法 index()
index(item)
返回与目标元素相匹配的首个元素的索引。
目标必须在元组中存在的,否则会报错
t = (1, 3, 2, 3, 2)
print(t.index(3))
t = ('h', 'e', 'l', 'l', 'o', 'r', 'w', 'o', 'r', 'l', 'd')
print(t.index('h'))
元组常用方法 count()
count(item)
:返回某个元素出现的次数。
入参:对象 item
返回:次数
t = (1, 2, 2, 3, 3, 3, 3)
print(t.count(3))
t = ('h', 'e', 'l', 'l', 'o', 'r', 'w', 'o', 'r', 'l', 'd')
print(t.count('h'))
元组解包
# 传统逐个赋值的方式
t = (1, 2, 3)
a = t[0]
b = t[1]
c = t[2]
print(a, b, c)
# 使用元组解包,一气呵成
a, b, c = (1, 2, 3)
print(a, b, c)
元组与列表对比
()
,列表使用 []
9.python常用数据结构-集合
集合定义
{}
包围,对象相互之间使用逗号分隔集合使用:创建
{}
填充元素"""创建集合"""
# 1、使用大括号{}填充元素
st4 = {1, 2, 3}
st5 = {'a', 'b', 'c'}
# 2、使用构造方法创建集合
st1 = set() # 空集合
st2 = set('hello world')
li = [1, 1, 2, 2, 3, 3]
st3 = set(li)
print(st3)
print(type(st3))
# 3、使用集合推导式
st6 = {x for x in li}
print(st6)
# 注意:不要单独使用{ }来创建空集合
st7 = {} # 这是字典类型
print(type(st7))
集合使用:成员检测:
"""集合使用:成员检测"""
st = {1, 2, 3, 4, 5}
# in
print(2 in st)
# not in
print(99 not in st)
集合方法
集合方法 add()
add(item)
:将单个对象添加到集合中"""集合方法 add()"""
# 添加元素
st = {1, 2, 3}
st.add(99)
st.add('hello')
print(st)
print(type(st))
集合方法 update()
update(iterable)
批量添加来自可迭代对象中的所有元素
入参:可迭代对象 iterable
返回:None
"""集合方法 update()"""
li = [1, 2, 3]
tup = (2, 3, 4)
st = {'a', 'b', 'c'}
# 1、批量添加列表中的元素
st1 = set()
st1.update(li)
print(st1)
# 2、批量添加元组中的元素
st1.update(tup)
print(st1)
# 3、批量添加集合中的元素
st1.update(st)
print(st1)
集合方法 remove()
remove(item)
:从集合中移除指定元素 item。"""集合方法 remove()"""
# 1、删除已存在的元素
st = {1, 2, 3, 4, 5}
print(st)
st.remove(2)
print(st)
# 2、删除不存在的元素
st.remove(1024) # KeyError
集合方法 discard()
discard(item)
:从集合中移除指定对象 item。"""集合方法 discard()"""
# 1、删除已存在的元素
st = {1, 2, 3, 4, 5}
print(st)
st.remove(2)
print(st)
# 2、删除不存在的元素
st.discard(1024)
print(st)
集合方法 pop()
pop()
:随机从集合中移除并返回一个元素。"""集合方法 pop()"""
# 1、随机删除某个对象
st = {1, 2, 3, 4, 5}
print(st)
item = st.pop()
print(item, st)
# 2、集合本身为空会报错
st = set()
st.pop() # KeyError
集合方法 clear()
clear()
:清空集合,移除所有元素"""集合方法 clear()"""
# 1、清空集合
st = {1, 2, 3, 4, 5}
print(st)
st.clear()
print(st)
集合运算
集合运算:交集
交集运算
intersection()
操作符:&
"""集合运算:交集"""
# 交集运算
set1 = {1, 3, 2}
set2 = {2, 4, 3}
print(set1.intersection(set2))
print(set1 & set2)
集合运算:并集
并集运算
union()
操作符:|
"""集合运算:并集"""
# 求两个集合的并集
set1 = {1, 3, 2}
set2 = {2, 4, 3}
print(set1.union(set2))
print(set1 | set2)
集合运算:差集
差集运算
difference()
操作符: -
"""集合运算:差集"""
# 集合求差集
set1 = {1, 3, 2}
set2 = {2, 4, 3}
print(set1.difference(set2))
print(set1 - set2)
集合推导式
{x for x in ... if ...}
st = set()
for s in "hold":
if s in "hello world":
st.add(s)
print(st)
print(type(st))
# 使用推导式生成集合
"""集合推导式"""
# 使用推导式生成集合
# 实例:寻找 hold 与 hello world的共相同字母
st = {x for x in 'hold' if x in 'hello world'}
print(st)
print(type(st))
10.python常用数据结构-字典
字典定义
{}
包围字典使用:创建
"""字典使用:创建"""
# 1、使用大括号填充键值对
dc = {'name': 'Harry Potter', 'age': 18}
print(type(dc), dc)
# 2、使用字典构造方法
dc1 = dict() # 空字典
dc2 = dict(name="Harry Potter", age=18) # 关键字参数赋值
print(type(dc2), dc2)
dc3 = dict([("name", "Harry Potter"), ("age", 18)])
print(type(dc3), dc3)
# 3、使用字典推导式
dc4 = {k: v for k, v in [("name", "Harry Potter"), ("age", 18)]}
print(type(dc4), dc4)
字典使用:访问元素
[key]
。"""字典使用:访问元素"""
dc = {"name": "Harry Potter", "age": 18}
# 1、访问存在的key
print(dc["name"])
print(dc["age"])
# 2、访问不存在的key,会报KeyError错误
print(dc['hobby'])
字典使用:操作元素
"""字典使用:操作元素"""
dc = {"name": "Harry Potter", "age": 18}
# 1、修改年龄,改为20
dc['age'] = 20
print(dc)
# 2、新增hobby字段
dc['hobby'] = 'Magic'
print(dc)
字典使用:嵌套字典
嵌套字典
字典的值可以是字典对象
"""字典使用:嵌套字典"""
dc = {"name": "Harry Potter", "age": 18, "course": {"magic": 90, "python": 80}}
# 1、获取课程Magic的值
print(dc['course']['magic'])
# 2、把python分数改成100分
dc['course']['python'] = 100
print(dc)
字典方法
字典方法 keys()
keys()
返回由字典键组成的一个新视图对象。
入参:无
"""字典方法 keys()"""
dc = {"name": "Harry Potter", "age": 18}
keys = dc.keys()
print(dc.keys())
print(dc.values())
print(dc.items())
# 1、遍历查看所有的键
for key in keys:
print(key)
# 2、将视图对象转成列表
print(list(keys))
print(list(dc.values()))
字典方法 values()
values()
返回由字典值组成的一个新视图对象。
"""字典方法 values()"""
dc = {"name": "Harry Potter", "age": 18}
values = dc.values()
print(type(values), values)
# 1、遍历查看所有的值
for value in values:
print(value)
# 2、将视图对象转成列表
print(list(values))
字典方法 items()
items()
返回由字典项 ((键, 值) 对) 组成的一个新视图对象。
"""字典方法 items()"""
dc = {"name": "Harry Potter", "age": 18}
items = dc.items()
print(type(items), items)
# 1、遍历查看所有的项
for item in items:
print(item)
# 2、将视图对象转成列表
print(list(items))
字典方法 get()
get(key)
获取指定 key 关联的 value 值。
入参:
返回:
此方法的好处是无需担心 key 是否存在,永远都不会引发 KeyError 错误。
"""字典方法 get()"""
dc = {"name": "Harry Potter", "age": 18}
# 1、访问存在的key
name = dc.get("name")
print(name)
# 2、访问不存在的key
hobby = dc.get('hobby')
print(hobby)
字典方法 update()
update(dict)
使用来自 dict 的键/值对更新字典,覆盖原有的键和值。
入参:
返回:None
dc = {"name": "Harry Potter", "age": 18}
dc.update({"age": 20, "hobby": "magic"})
print(dc)
字典方法 pop()
pop(key)
删除指定 key 的键值对,并返回对应 value 值。
入参:
返回:
"""字典方法 pop()"""
dc = {"name": "Harry Potter", "age": 18}
# 1、弹出
item = dc.pop("age")
print(dc, item)
# 2、删除不存在的key
dc.pop("hobby") # 报错keyError
字典推导式
字典推导式:可以从任何以键值对作为元素的可迭代对象中构建出字典。
实例:给定一个字典对象{'a': 1, 'b': 2, 'c': 3}
,找出其中所有大于 1 的键值对,同时 value 值进行平方运算。
# 未使用字典推导式的写法
dc = {'a': 1, 'b': 2, 'c': 3}
d_old = dict()
for k, v in dc.items():
if v > 1:
d_old[k] = v ** 2
print(d_old)
# 使用字典推导式
d_new = {k: v ** 2 for k, v in dc.items() if v > 1}
print(d_new)
练习:
# 给定一个字典对象,请使用字典推导式,将它的key和value分别进行交换。也就是key变成值,值变成key。
# 输入:{'a':1,'b':2,‘c':3}
# 输出:{1:'a',2:'b',3:'c'}
dic = {'a': 1, 'b': 2, 'c': 3}
print(dic)
print({v: k for k, v in dic.items()})
11.python函数
函数的作用
函数定义
def function_name([parameter_list]):
[''' comments ''']
[function_body]
定义函数的注意事项
ctrl+alt+L
pass
语句占位函数调用
function_name([parameter_value])
参数传递
# a, b, c 为形式参数
def demo_func(a, b, c):
print(a, b, c)
# 1, 2, 3 为实际参数
demo_func(1, 2, 3)
位置参数
def demo_func(a, b, c):
print(a, b, c)
# 1 赋值给 a, 2 赋值给 b, 3 赋值给 c
demo_func(1, 2, 3)
关键字参数
def demo_func(a, b, c):
print(a, b, c)
demo_func(a=1, b=2, c=3)
为参数设置默认值
param=default_value
:可选,指定参数并且为该参数设置默认值为 default_valuedef function_name(..., [param=default_value]):
[function_body]
函数返回值
- value:可选,指定要返回的值
def function_name([parameter_list]): [''' comments '''] [function_body] return [value]
def sum(a, b):
result = a + b
return result
ret = sum(1, 3)
print(ret)
12.python函数进阶与参数处理
可变参数
*args
**kwargs
*args
*
def print_language(*args):
print(args)
print_language("python", "java", "php", "go")
params = ["python", "java", "php", "go"]
print_language(*params)
**kwargs
**
def print_info(**kwargs):
print(kwargs)
print_info(Tom=18, Jim=20, Lily=12)
params = {'Tom': 18, 'Jim': 20, 'Lily': 12}
print_info(**params)
13.pythonlambda表达式
匿名函数
使用场景
语法
result = lambda [arg1 [, arg2, .... , argn]]: expression
# 1.常规写法
def cricle_area(r):
result = math.pi * r * r
return result
r = 2
print(f"半径为{r}的圆的面积为{cricle_area(r)}")
# 2.使用lambda表达实现
r = 2
result = lambda r: math.pi * r * r
print(f"半径为{r}的圆的面积为{result(r)}")
print(lambda r: math.pi * r * r)
# 对获取到的信息进行排序
# #书籍信息
book_info = [("python零基础入门", 22.5), ("java 零基础入门", 20), ("软件测试零基础入门", 25)]
print(type(book_info))
print(book_info)
# 指定规则进行排序
# 第一个x表示一个对象,比如("python零基础入门", 22.5)
# 第二个x表示对象的索引
book_info.sort(key=lambda x: (x[1]))
print(book_info)
14.python面向对象概念
面向对象是什么?
OOP
):Object Oriented Programming
所谓的面向对象,就是在编程的时候尽可能的去模拟真实的现实世界,按照现实世界中的逻辑去处理问题,分析问题中参与其中的有哪些实体,这些实体应该有什么属性和方法,我们如何通过调用这些实体的属性和方法去解决问题。
两种编程思想
类与对象
类(class
): 用来描述具有相同的属性和方法的对象的集合。它定义了集合中每个对象所共有的属性和方法。
对象(object
):也称为类的实例,是一个具体存在的实体。
15.python类与对象
类的定义
class
关键字# 语法
class 类名(父类名):
"""类的帮助信息"""
属性
方法
# 类的声明
class Human(object):
"""人类"""
# 定义属性(类属性)
message = "这是类属性"
# 通过类访问类属性
print(Human.message)
类的方法
构造方法与实例化
def __init__(self, 参数列表)
类名(参数列表)
class Human:
# 定义属性(类属性)
message = "这是类属性"
# 构造方法
def __init__(self, name, age):
# 实例变量
self.name = name
self.age = age
print("这是构造方法")
# 实例化对象
person = Human("哈利波特", 12)
# 通过实例访问类属性
print(person.message)
# 通过实例访问实例属性
print(person.name)
print(person.age)
实例方法
def 方法名(self, 参数列表)
实例.方法名(参数列表)
class Human:
# 实例方法
def study(self, course):
print(f"正在学习{course}")
# 实例化
person = Human()
# 通过实例访问实例方法
person.study("python")
类方法
@classmethod
类名.类方法名(参数列表)
class Human:
# 类属性
population = 0
# 类方法
@classmethod
def born(cls):
print("这是类方法")
cls.population += 1
# 通过类名访问类方法
Human.born()
print(Human.population)
静态方法
@staticmethod
class Human:
# 静态方法
@staticmethod
def grow_up():
print("这是静态方法")
# 通过类名访问静态方法
Human.grow_up()
16.学生信息管理系统
编写学员实体类 Student,对应成员变量包含:学号 id、姓名 name、性别 sex;
编写学员管理类 StudentManagement ,实现添加学员方法 addStudent()。
编写StudentManagement的main方法进行学员信息的添加:
学号:1001,姓名:张三,性别:男。
学号:1002,姓名:莉丝,性别:女。
学号:1003,姓名:王武,性别:男。
class Student:
def __init__(self, id, name, sex):
self.id = id
self.name = name
self.sex = sex
class StudentManagement:
def __init__(self):
pass
def addStudent(self, id, name, sex):
student = Student(id, name, sex)
print(f"添加学员成功:{student.id}, {student.name}, {student.sex}")
def main(self):
# 添加学员1
self.addStudent(1001, "张三", "男")
# 添加学员2
self.addStudent(1002, "莉丝", "女")
# 添加学员3
self.addStudent(1003, "王武", "男")
stumg = StudentManagement()
stumg.main()
运行结果: