1.容器型數(shù)據(jù)類型: 列表格仲、元祖搁廓、字典引颈、集合
1)列表:
[元素1, 元素2,...]
可變、有序
增刪改查境蜕、+,*,>,<,>=,<=,==,!=,is线欲、in,not in、len()汽摹、list()
多個(gè)數(shù)據(jù)的意義相同李丰,并且需要支持增刪改操作
2)元祖:
(元素1, 元素2,....)、 (元素1,)逼泣、 元素1, 元素2,....
不可變趴泌、有序
查舟舒、+,*,>,<,>=,<=,==,!=,is、in,not in嗜憔、len()秃励、tuple()
一般選擇容器存儲(chǔ)數(shù)據(jù)的時(shí)候不用元祖。 存儲(chǔ)不可變數(shù)據(jù)的時(shí)候才用
3)字典
{鍵1:值1, 鍵2:值2,...} , 鍵 - 不可變的吉捶、唯一 值 - 任何類型的數(shù)據(jù)
可變夺鲜、無序
增刪改查、==,!=,is呐舔、in,not in币励、len()、dict()
保存的多個(gè)數(shù)據(jù)需要區(qū)分(意義/性質(zhì)不同)
4)集合
{元素1, 元素2,...} 元素 - 不可變的珊拼、唯一
可變食呻、無序
增刪查、==,!=,is澎现、in,not in仅胞、len()、set()剑辫、數(shù)學(xué)集合運(yùn)算(|, &, -, ^, >=, <=)
注意: 集合遍歷的效率高
做數(shù)學(xué)集合運(yùn)算操作干旧、去重、提高程序效率
2.函數(shù)
- 聲明
def 函數(shù)名(參數(shù)列表):
函數(shù)體
注意: 函數(shù)聲明的時(shí)候不會(huì)執(zhí)行函數(shù)體!
- 調(diào)用
函數(shù)(參數(shù)列表)
注意: 函數(shù)調(diào)用之前必須已經(jīng)聲明過
**調(diào)用過程:
回到函數(shù)聲明的位置
傳參(傳參要保證每個(gè)參數(shù)都有值)
執(zhí)行函數(shù)體
執(zhí)行完函數(shù)體確定返回值
回到函數(shù)調(diào)用的位置(這個(gè)時(shí)候函數(shù)調(diào)用表達(dá)式的值就是返回值)
參數(shù)
位置參數(shù)妹蔽、關(guān)鍵字參數(shù) -- 保證位置參數(shù)在關(guān)鍵字參數(shù)的前面
參數(shù)默認(rèn)值
類型說明
不定長(zhǎng)參數(shù) -- args,*kwargs (面試題)返回值
怎么確定返回值
怎么獲取返回值: 獲取函數(shù)調(diào)用表達(dá)式的值其他
lambda 參數(shù)列表: 返回值
變量的作用域:
全局變量: 聲明在函數(shù)/類外部的變量是全局變量
局部變量: 聲明在函數(shù)里面的變量就是局部變量
global: 在函數(shù)中聲明全局變量
nonlocal: 想要在局部的局部中去修改局部變量的值
nums = [12, 3, 89, 90, 8]
nums.sort(reverse=True)
print(nums)
print('==================')
print(print('abc'))
func1 = lambda x: x*2
result = func1(10)
print(result)
list1 = [10, lambda x: x*x]
result = list1[1](10)
print(result)
# 1.編寫函數(shù)莱革,求1+2+3+…N的和
def yt_sum1(n):
return sum(range(1, n+1))
print(yt_sum1(10))
2.編寫一個(gè)函數(shù),求多個(gè)數(shù)中的最大值
def yt_max(*nums):
max1 = nums[0]
for num in nums[1:]:
if num > max1:
max1 = num
return max1
print(yt_max(19, 992, -93, 0))
4. 編寫一個(gè)函數(shù)讹开,交換指定字典的key和value
dict1 = {'a': 1, 'b': 2} # {1: 'a', 2: 'b'}
def exchange_key_value(dictx: dict):
# 注意: 遍歷刪除和增加盅视,遍歷對(duì)象應(yīng)該原來沒有進(jìn)行修改的原容器的值。
for key in dictx.copy():
value = dictx[key]
print(key)
dictx.pop(key)
dictx[value] = key
exchange_key_value(dict1)
print(dict1)
9.寫一個(gè)自己的endswith函數(shù)旦万,判斷一個(gè)字符串是否已指定的字符串結(jié)束
例如: 字符串1:'abc231ab' 字符串2:'ab' 函數(shù)結(jié)果為: True
字符串1:'abc231ab' 字符串2:'ab1' 函數(shù)結(jié)果為: False
def endswith(str1: str, str2: str):
len2 = len(str2)
end = str1[-len2:]
return end == str2
if endswith('text.c', '.py'):
print('是python源文件')
else:
print('不是python源文件')
10.寫一個(gè)自己的isdigit函數(shù)闹击,判斷一個(gè)字符串是否是純數(shù)字字符串
例如: '1234921' 結(jié)果: True
'23函數(shù)' 結(jié)果: False
'a2390' 結(jié)果: False
def isdigit(str1: str):
for char in str1:
if not '0' <= char <= '9':
return False
return True
print(isdigit('2a333'))
12.寫一個(gè)自己的rjust函數(shù),創(chuàng)建一個(gè)字符串的長(zhǎng)度是指定長(zhǎng)度成艘,原字符串在新字符串中右對(duì)齊赏半,剩下的部分用指定的字符填充
例如: 原字符:'abc' 寬度: 7 字符:'^' 結(jié)果: '^^^^abc'
原字符:'你好嗎' 寬度: 5 字符:'0' 結(jié)果: '00你好嗎'
def rjust(str1: str, width: int, char: str):
count = width - len(str1)
return count*char+str1
print(rjust('abc', 7, '^'))
print(rjust('你好嗎', 5, '0'))
13.寫一個(gè)自己的index函數(shù),統(tǒng)計(jì)指定列表中指定元素的所有下標(biāo)淆两,如果列表中沒有指定元素返回-1
例如: 列表: [1, 2, 45, 'abc', 1, '你好', 1, 0] 元素: 1 結(jié)果: 0,4,6
列表: ['趙云', '郭嘉', '諸葛亮', '曹操', '趙云', '孫權(quán)'] 元素: '趙云' 結(jié)果: 0,4
列表: ['趙云', '郭嘉', '諸葛亮', '曹操', '趙云', '孫權(quán)'] 元素: '關(guān)羽' 結(jié)果: -1
def index(list1: list, item):
if item not in list1:
return -1
indexs = []
for x in range(len(list1)):
if list1[x] == item:
indexs.append(x)
return indexs
names = ['趙云', '郭嘉', '諸葛亮', '曹操', '趙云', '孫權(quán)']
all_index = index(names, '趙云')
for x in all_index:
names[x] = '子龍'
print(index(names, '關(guān)羽'))
print(names)
14.寫一個(gè)自己的max函數(shù)断箫,獲取指定序列中元素的最大值。如果序列是字典秋冰,取字典值的最大值
例如: 序列:[-7, -12, -1, -9] 結(jié)果: -1
序列:'abcdpzasdz' 結(jié)果: 'z'
序列:{'小明':90, '張三': 76, '路飛':30, '小花': 98} 結(jié)果: 98
print(max([23, 45, 34, 45]))
print(max({'name': '張三', 'zge': 16, 'gender': '女'}))
def yt_max(seq):
if isinstance(seq, dict):
values = list(seq.values())
else:
values = list(seq)
max1 = values[0]
for item in values[1:]:
if item > max1:
max1 = item
return max1
print(yt_max([23, 45, 56, 56]))
print(yt_max({'a', 'nsh', 'bccc'}))
print(yt_max({'小明': 90, '張三': 76, '路飛
1.函數(shù)作為變量
python中聲明函數(shù)其實(shí)就是聲明一個(gè)類型是function的變量, 函數(shù)名就是變量名
所以普通變量能做的事情函數(shù)都可以做
def func1():
print('這是一個(gè)函數(shù)')
return 100
2. 一個(gè)變量可以給另外一個(gè)變量賦值
a = 10
b = a
print(b/2)
a = 'abc'
print(a)
c = func1 # 將函數(shù)名作為變量仲义,給另一個(gè)變量賦值
print('=======')
print(c())
print('=======')
func1 = 12.5
print(func1)
# print(func1()) # TypeError: 'float' object is not callable
# 3. 一個(gè)變量可以作為容器的元素
print('===================================')
a = 10 # 聲明一個(gè)變量,類型是整型
print(type(a))
# 聲明一個(gè)變量,類型是function
def func2():
print('這是函數(shù)2')
return 100
print(type(func2))
list1 = [a, func2, func2()]
print(list1)
print('0:', list1[0] // 3)
print('1:', list1[1]()) # print('1:', func2()) -> print('1:', 100)
練習(xí):
list2 = []
for i in range(5):
def func(n):
return i * 2
list2.append(func)
list3 = []
for i in range(5):
list3.append(lambda x: x*i)
print(list3[0](2), list3[1](2), list3[2](2))
list2 = []
i = 0 ~ 4
i = 0: func, list2 = [func]
i = 1: func, list2 = [func, func]
...
i = 4: list2 = [func,func,func,func,func]
list20, list21, list22
func, func, func
None, None, None
0, 2, 3
8, 8, 8
print(list2)
print(list2[0](3), list2[1](3), list2[2](3))
4. 變量可以作為函數(shù)的參數(shù)
函數(shù)作為函數(shù)的參數(shù)(實(shí)參高階函數(shù))
print('==============================')
def func1(fn, fn2):
# fn = func11
# fn2 = func12
fn() # func11(), None
print(fn2(3) / 4) # print(9/4)
def func11():
print('這是一個(gè)函數(shù)')
def func12(n):
# n = 3
return n**2
print(func1(func11, func12)) # print(None)
func1(func11, func12)
應(yīng)用: sort函數(shù)
print('===============sort的高級(jí)使用===============')
nums = [1, 34, 45, 9, 20]
nums.sort()
print(nums)
all_students = [
{'name': '小明', 'age': 19, 'score': 89},
{'name': '熊大', 'age': 20, 'score': 90},
{'name': '熊二', 'age': 17, 'score': 70},
{'name': '光頭強(qiáng)', 'age': 21, 'score': 40}
]
序列.sort函數(shù)中有個(gè)參數(shù)key埃撵,這個(gè)參數(shù)要求傳一個(gè)函數(shù)赵颅,并且函數(shù)有一個(gè)參數(shù)和一個(gè)返回值
參數(shù)就是序列中的元素, 返回值就是排序比較的對(duì)象
def compare(item):
return item['age']
all_students.sort(key=compare)
all_students.sort(key=lambda item: item['age'])
print(all_students)
練習(xí),將all_message中的元祖按照第二個(gè)元素從大到小排序暂刘。然后再按照學(xué)號(hào)的最后一位從小到大排序
all_message = [
('余婷', 'python1902004'),
('張三', 'python1902106'),
('小明', 'python1902027')
]
all_message.sort(key=lambda item: item[1], reverse=True)
print(all_message)
all_message.sort(key=lambda item: item[1][-1])
print(all_message)
def yt_sort(seq, key=None, reverse=False):
if key:
# 選擇排序
length = len(seq)
for x in range(length - 1):
for y in range(x + 1, length):
if key(seq[y]) < key(seq[x]):
seq[x], seq[y] = seq[y], seq[x]
else:
# 選擇排序
length = len(seq)
for x in range(length-1):
for y in range(x+1, length):
if seq[y] < seq[x]:
seq[x], seq[y] = seq[y], seq[x]
nums = [23, 45, 89, 9, 21]
yt_sort(nums)
nums.sort()
print(nums)
all_students = [
{'name': '小明', 'age': 19, 'score': 89},
{'name': '熊大', 'age': 20, 'score': 90},
{'name': '熊二', 'age': 17, 'score': 70},
{'name': '光頭強(qiáng)', 'age': 21, 'score': 40}
]
all_students.sort(key=lambda x: x['age'])
yt_sort(all_students, key=lambda x: x['age'])
print(all_students)
all_students = [
{'name': '小明', 'age': 19, 'score': 89},
{'name': '熊大', 'age': 20, 'score': 90},
{'name': '熊二', 'age': 17, 'score': 70},
{'name': '光頭強(qiáng)', 'age': 21, 'score': 40}
]
print(max(all_students, key=lambda x: x['score']))
5. 變量作為返回值
將一個(gè)函數(shù)作為函數(shù)的返回值(返回值高階函數(shù))
print('================返回值高階函數(shù)==============')
def func1():
def temp(*nums):
return sum(nums)
return temp
print(func1()(1, 3, 5, 9)) # print(temp(1,3,5,9)) , print(18)
1.什么是迭代器(iter)
迭代器是容器型數(shù)據(jù)類型(可以同時(shí)存儲(chǔ)多個(gè)數(shù)據(jù)), 但是想要獲取/查看迭代器中元素的值饺谬,只能將元素取出來。
取出來的元素在迭代器中就不存在了谣拣,取的時(shí)候只能從前往后一個(gè)一個(gè)的取募寨,不能跳著取。
2.迭代器中的元素
迭代器的元素只能通過類型轉(zhuǎn)換森缠,將其他容器轉(zhuǎn)換成迭代器拔鹰; 或者通過生成器去生成
1) 轉(zhuǎn)換 - 所有序列都可以轉(zhuǎn)換成迭代器。 迭代器中的元素可以是任何類型的數(shù)據(jù)
iter1 = iter([10, [1, 3]])
print(iter1)
3. 獲取元素: 迭代器獲取元素辅鲸,不管以什么樣的方式獲取格郁,獲取后腹殿,這個(gè)元素在迭代器中就不存在了
1) next(迭代器) - 獲取迭代器頂部數(shù)據(jù)(最上面的數(shù)據(jù))
iter2 = iter('hello')
print(next(iter2))
print(next(iter2))
print(next(iter2))
print(next(iter2))
print(next(iter2))
print(next(iter2)) # StopIteration
2) 遍歷獲取每個(gè)元素
iter2 = iter('hello')
next(iter2)
next(iter2)
for x in iter2:
print('x:', x)
print(next(iter2)) # StopIteration
1.什么是生成器
生成器就是迭代器, 迭代器不一定是生成器
調(diào)用一個(gè)帶有yield關(guān)鍵字的函數(shù)就能得到一個(gè)生成器独悴。(yield只能出現(xiàn)在函數(shù)體中)
def func1():
print('=====')
return 100
yield
gen1 = func1()
gen2 = func1()
print(gen1, gen2)
2.生成器的元素
生成器獲取元素的方式和迭代器一樣: next()和循環(huán)遍歷
1)生成器元素的個(gè)數(shù): 看執(zhí)行完生成器對(duì)應(yīng)的函數(shù)會(huì)遇到幾次yield
2) 元素的值: 看yield后表達(dá)式的值
def func2():
print('函數(shù)')
for x in range(10):
yield x
gen3 = func2()
print('next:', next(gen3))
print('next:', next(gen3))
print('next:', next(gen3))
print('next:', next(gen3))
for x in gen3:
print('x:', x)
3.生成器產(chǎn)生數(shù)據(jù)的原理
"""
當(dāng)獲取生成的元素的是,會(huì)執(zhí)行生成器對(duì)應(yīng)的函數(shù)锣尉,從開始執(zhí)行到y(tǒng)ield為止,將yield后面的數(shù)據(jù)作為元素返回并且記錄結(jié)束位置刻炒;
下次獲取元素的時(shí)候,從上次結(jié)束的位置接著往后執(zhí)行自沧,直到遇到y(tǒng)ield, 將yield后面的數(shù)據(jù)作為元素返回并且記錄結(jié)束位置坟奥;
以此類推
如果從開始執(zhí)行到函數(shù)結(jié)束,沒有遇到y(tǒng)ield拇厢,那么就獲取不到元素
"""
print('===============================')
def func3():
print('第一次')
yield 1
print('第二次')
yield 2
print('第三次')
yield 3
gen4 = func3()
print('next1:', next(gen4))
for x in range(100):
print('+++++++++++++')
print('next2:', next(gen4))
print('next3:', next(gen4))
nums = ['001', '002', '003', '004', '005', '006']
def func5():
for x in range(1, 6):
yield str(x).rjust(3, '0')
nums2 = func5()
print(next(nums2))
print(next(nums2))
能夠產(chǎn)生無限數(shù)字的生成器
def func6():
num = 0
while True:
yield num
num += 1
gen5 = func6()