案例1: 判斷 list 內(nèi)有無重復(fù)元素
def is_duplicated(lst):
for x in lst:
if lst.count(x) > 1:
return True
return False
a = [1, -2, 3, 4, 1, 2]
print(is_duplicated(a))
def is_duplicated(lst):
return len(lst) != len(set(lst))
案例2: 列表反轉(zhuǎn)
def reverse(lst):
return lst[::-1]
r = reverse([1, -2, 3, 4, 1, 2])
print(f)
案例3:找出列表中的所有重復(fù)元素
def find_duplicate(lst):
ret = []
for x in lst:
if lst.count(x) > 1 and x not in ret:
ret.append(x)
return ret
r = find_duplicate([1, 2, 3, 4, 3, 2])
print(r)
案例4:斐波那契數(shù)列
def fibonacci(n):
if n <= 1:
return [1]
fib = [1, 1]
while len(fib) < n:
fib.append(fib[len(fib) - 1] + fib[len(fib) - 2])
return fib
r = fibonacci(5)
print(r)
# 生成器版本
def fibonacci(n):
a, b = 1, 1
for _ in range(n):
yield a
a, b = b, a + b
list(fibonacci(5))
案例5:出鏡最多
# 求出現(xiàn)頻次最多的元素
def mode(lst):
if not lst:
return None
return max(lst, key=lambda v: lst.count(v))
# 調(diào)用mode
lst = [1, 3, 2, 1, 2, 2]
r = mode(lst)
print(f'{lst}中出現(xiàn)次數(shù)最多的元素是:{r}')
案例6:更長列表
帶有一個 * 的參數(shù)為可變位置參數(shù),意味著能傳入任意多個位置參數(shù)。
key 函數(shù)定義怎么比較大性锟辍:lambda 的參數(shù) v 是 lists 中的一個元素。
def max_len(*lists):
return max(*lists, key=lambda v: len(v))
r = max_len([1, 2, 3], [4, 5, 6, 7], [8])
print(r'更長的列表是{r}')
案例7:求表頭
# 返回列表的第一個元素
def head(lst):
return lst[0] if len(lst) > 0 else None
print(head([1, 2, 3]))
案例8:求表尾
def tail(lst):
return lst[-1] if len(lst) > 0 else None
案例9:打印乘法表
def mul_table():
for i in range(1, 10):
for j in range(1, i+1):
print(str(j) + '*' + str(i) + '=' + str(j*i) , end='\t' )
print()
mul_table()
案例10:元素對
# zip(iter1, iter2):實(shí)現(xiàn) iter1 和 iter2 的對應(yīng)索引處的元素拼接
def pair(t):
return list(zip(t[:-1], t[1:]))
print(list(pair([1, 2, 3])))
案例11:樣本抽樣
# 從含100個樣本的列表中隨機(jī)抽取10個樣本
from random import randint, sample
lst = [randint(0, 50) for _ in range(100)]
print(lst[:5])
lst_sample = sample(lst, 10)
print(lst_sample)
案例12:重洗數(shù)據(jù)集
# shuffle對輸入列表就地洗牌两芳,節(jié)省存儲空間
from random import shuffle
lst = [randint(0, 50) for _ in range(100)]
shuffle(lst) # 重洗數(shù)據(jù)
print(lst[:5])
案例13:生成滿足均勻分布的坐標(biāo)點(diǎn)
# random的uniform(a, b)生成[a, b)內(nèi)的一個隨機(jī)數(shù)
from random import uniform
x, y = [ i for i in range(100)] ,[round(uniform(0, 10) , 2) for _ in range(100)]
print(y)
# 使用pyecharts繪圖
from pyecharts.charts import Scatter
import pyecharts.options as opts
from random import uniform
def draw_uniform_points():
x, y = [i for i in range(100)], [round(uniform(0, 10), 2) for _ in range(100)]
print(y)
c = (
Scatter()
.add_xaxis(x)
.add_yaxis('y', y)
)
c.render()
draw_uniform_points()