python基礎(16):內置函數(二)

来源:https://www.cnblogs.com/liuhui0308/archive/2019/11/07/11815968.html
-Advertisement-
Play Games

1. lamda匿名函數 為瞭解決⼀些簡單的需求⽽設計的⼀句話函數 # 計算n的n次⽅ def func(n): return n**n print(func(10)) f = lambda n: n**n print(f(10)) lambda表⽰的是匿名函數,不需要⽤def來聲明,⼀句話就可以聲 ...


1. lamda匿名函數

為瞭解決⼀些簡單的需求⽽設計的⼀句話函數
# 計算n的n次⽅
def func(n):
  return n**n
print(func(10))

f
= lambda n: n**n print(f(10))
lambda表⽰的是匿名函數,不需要⽤def來聲明,⼀句話就可以聲明出⼀個函數。 語法:
函數名 = lambda 參數: 返回值
註意:
1. 函數的參數可以有多個,多個參數之間⽤逗號隔開 2. 匿名函數不管多複雜,只能寫⼀⾏,且邏輯結束後直接返回數據 3. 返回值和正常的函數⼀樣,可以是任意數據類型
匿名函數並不是說⼀定沒有名字,這⾥前⾯的變數就是⼀個函數名,說他是匿名原因是我們通過__name__查看的時候是沒有名字的,統⼀都叫lambda,在調⽤的時候沒有什麼特別之處,像正常的函數調⽤即可。

2. sorted()

排序函數。 語法:
sorted(Iterable, key=None, reverse=False)   Iterable: 可迭代對象   key: 排序規則(排序函數),在sorted內部會將可迭代對象中的每⼀個元素傳遞給這個函數的參數,根據函數運算的結果進⾏排序   reverse: 是否是倒敘,True: 倒敘,False: 正序
lst = [1,5,3,4,6]
lst2 = sorted(lst)
print(lst) # 原列表不會改變
print(lst2) # 返回的新列表是經過排序的

dic = {1:'A', 3:'C', 2:'B'} print(sorted(dic)) # 如果是字典. 則返回排序過後的key
和函數組合使⽤
# 根據字元串⻓度進⾏排序
lst = ["麻花藤", "岡本次郎", "中央情報局", "狐仙"]

# 計算字元串⻓度 def func(s):   return len(s) print(sorted(lst, key=func))
和lambda組合使⽤
# 根據字元串⻓度進⾏排序
lst = ["麻花藤", "岡本次郎", "中央情報局", "狐仙"]

# 計算字元串⻓度 def func(s):   return len(s)
print(sorted(lst, key=lambda s: len(s)))
lst
= [{"id":1, "name":'alex', "age":18}, {"id":2, "name":'wusir', "age":16}, {"id":3, "name":'taibai', "age":17}] # 按照年齡對學⽣信息進⾏排序 print(sorted(lst, key=lambda e: e['age']))

3. filter()

篩選函數 語法:
fifilter(function. Iterable)   function: ⽤來篩選的函數,在fifilter中會⾃動的把iterable中的元素傳遞給function,然後根據function返回的True或者False來判斷是否保留此項數據   Iterable: 可迭代對象
lst = [1,2,3,4,5,6,7]
ll = filter(lambda x: x%2==0, lst) # 篩選所有的偶數
print(ll)
print(list(ll))

lst
= [{"id":1, "name":'alex', "age":18}, {"id":2, "name":'wusir', "age":16}, {"id":3, "name":'taibai', "age":17}] fl = filter(lambda e: e['age'] > 16, lst) # 篩選年齡⼤於16的數據 print(list(fl))

4. map()

映射函數 語法:
map(function, iterable) 可以對可迭代對象中的每⼀個元素進⾏映射,分別取執⾏function
計算列表中每個元素的平⽅ ,返回新列表
def func(e):
  return e*e
mp = map(func, [1, 2, 3, 4, 5])
print(mp)
print(list(mp))
改寫成lambda
print(list(map(lambda x: x * x, [1, 2, 3, 4, 5])))
計算兩個列表中相同位置的數據的和
# 計算兩個列表相同位置的數據的和
lst1 = [1, 2, 3, 4, 5]
lst2 = [2, 4, 6, 8, 10]
print(list(map(lambda x, y: x+y, lst1, lst2)))

5. 遞歸

在函數中調⽤函數本⾝,就是遞歸
def func():
  print("我是誰")
  func()
func()
在python中遞歸的深度最⼤到998
def foo(n):
  print(n)
  n += 1
  foo(n)
foo(1)
遞歸的應⽤: 我們可以使⽤遞歸來遍歷各種樹形結構,比如我們的⽂件夾系統,可以使⽤遞歸來遍歷該⽂件夾中的所有⽂件。
import os
def read(filepath, n):
  files = os.listdir(filepath) # 獲取到當前⽂件夾中的所有⽂件
  for fi in files: # 遍歷⽂件夾中的⽂件, 這⾥獲取的只是本層⽂件名
    fi_d = os.path.join(filepath,fi) # 加⼊⽂件夾 獲取到⽂件夾+⽂件
    if os.path.isdir(fi_d): # 如果該路徑下的⽂件是⽂件夾
      print("\t"*n, fi)
      read(fi_d, n+1) # 繼續進⾏相同的操作
    else:
      print("\t"*n, fi) # 遞歸出⼝. 最終在這⾥隱含著return

#
遞歸遍歷⽬錄下所有⽂件 read('../oldboy/', 0)

6. 二分查找

⼆分查找,每次能夠排除掉⼀半的數據,查找的效率非常⾼,但是局限性比較⼤,必須是有 序序列才可以使⽤⼆分查找。 要求: 查找的序列必須是有序序列。
# 判斷n是否在lst中出現. 如果出現請返回n所在的位置
# ⼆分查找---⾮遞歸演算法
lst = [22, 33, 44, 55, 66, 77, 88, 99, 101, 238, 345, 456, 567, 678, 789]
n = 567
left = 0
right = len(lst) - 1
count = 1
while left <= right:
  middle = (left + right) // 2
  if n < lst[middle]:
    right = middle - 1
  elif n > lst[middle]:
    left = middle + 1
  else:
    print(count)
    print(middle)
    break
  count = count + 1
else:
  print("不存在")

# 普通遞歸版本⼆分法 def binary_search(n, left, right):   if left <= right:     middle = (left+right) // 2     if n < lst[middle]:       right = middle - 1     elif n > lst[middle]:       left = middle + 1     else:       return middle     return binary_search(n, left, right) # 這個return必須要加. 否則接收到的永遠是None.   else:     return -1
print(binary_search(567, 0, len(lst)-1))
# 另類⼆分法, 很難計算位置. def binary_search(ls, target):   left = 0   right = len(ls) - 1   if left > right:     print("不在這⾥")   middle = (left + right) // 2   if target < ls[middle]:     return binary_search(ls[:middle], target)   elif target > ls[middle]:     return binary_search(ls[middle+1:], target)   else:     print("在這⾥")
binary_search(lst,
567)

您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 1.首先是對vs2017這款軟體的使用 1.VS中的scanf()這個函數的使用問題 直到這次寫代碼我才知道VS中用scanf是會被警告的,VS中正規的類似於scanf()函數的輸入函數是scanf_s()只有使用這個函數你才不會報錯,它有三個參分別是數據類型,地址,最大存儲量, 還有兩種方法 第一 ...
  • 寶塔官方建議是純凈的系統,我使用docker運行一個ubuntu容器,模擬一個純凈的系統,這樣也不會影響到我的其他服務。 docker run --name baota -id -p 8888:8888 ubuntu docker exec -it baota bashapt-get updatea ...
  • 一個程式就是一個世界,有很多對象(變數) Golang 語言面向對象編程說明 1) Golang 也支持面向對象編程(OOP),但是和傳統的面向對象編程有區別,並不是純粹的面向對 象語言。所以我們說 Golang 支持面向對象編程特性是比較準確的。 2) Golang 沒有類(class),Go 語 ...
  • 雙11臨近的我發現自己真的很窮很窮很窮(重要的問題說三遍)…… 貧窮催人上進。於是我就尋思著在空閑時間自己搗鼓一下錢生錢的游戲是怎麼玩的,畢竟就算註定做韭菜也要做一根有知識有理想的韭菜。 第一個要玩的模型就是股票交易中的均線黃金交叉。 作為一個基礎的韭菜一定聽說過均線黃金交叉原則,也就是說當短期移動 ...
  • Python繪圖庫Turtle Turtle介紹 Turtle是Python內嵌的繪製線、圓以及其他形狀(包括文本)的圖形模塊。 一個Turtle實際上是一個對象,在導入Turtle模塊時,就創建了對象,然後,可以調用Turtle對象的各種方法完成不同的操作。 當創建一個Turtle對象時,它的位置 ...
  • 寫在前面的話 適用讀者:有一定經驗的,本文不適合初學者,因為可能不能理解我在說什麼 文章思路:不會一開始就像別的博客文章那樣,Bean 的生命周期,源碼解讀(給你貼一大堆的源碼)。個人覺得應該由問題驅動,為什麼為出現 BeanFactory ,為什麼會有生命周期。 正文 一開始我們使用 bean 都 ...
  • 1、Eureka服務端集群開發 1、先創建一個父工程 若是不是普通demo,還有別的配置時,需要註意若是服務開不起來可能就是父類依賴中可能會需要<dependencyManagement>這個標簽。 2、再創建兩個子工程 1、導入依賴 <dependency> <groupId>org.spring ...
  • 1 簡介 我們知道 只是一個介面,它有多種實現,Java中最常用的是 了。而本文想講述的是另一個實現: 。它是枚舉類型的 ,要求它的Key值都必須是枚舉型的。 2 創建你的EnumMap 既然是關於枚舉類型的Map,我們先創建一個枚舉,以便後續使用: 2.1 創建EnumMap的三種方法 JDK提供 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...