函數
叫 子過程或子程序 描敘的更爲貼近實際應用場景
這和數學中的函數實現上不一樣但語義上相識,如 f(x) = expressiom, 給定一個肯定的輸入必然返回一個肯定的輸出
數學中函數的關係是經過代數方程肯定的,計算機中的函數關係經過 表達式語句肯定的,計算機能夠完成數學中函數的
表達,而且遠比數學中的函數要強大,數學中完成的僅僅是計算問題,計算機不單單完成計算還能同時自動完成相關聯的
運算與許多系統級別的工做python
在學習函數以前,咱們理解這個場景,好比你在畫畫,你須要什麼?一支畫筆和一張白紙就足夠了,類比
計算機程序,你須要一個空文本文件和往空文本文件中寫入程序,文本編輯器就是那支畫筆,空白文件就是那張白紙,
畫畫中,咱們要熟知幾種圖形與線條,在程序中咱們要熟知函數、類、變量、循環分支,這些都是構成程序的基本構件express
函數定義框架
def ...(param, ...): ... return expression, ...
1. 關鍵字def引入一個函數定義,後面跟函數名稱和函數的參數列表,而後最後以:做爲結尾,下一行縮進表示函數體
2. 定義的語義是建立了一個東西而後給予這個東西一個名字,而後後面某個時候能夠經過名字來引用這個東西,要想用
某個東西,就須要建立這個東西並給他一個名字
3. 調用函數 ...(param, ...),這個過程又被稱爲執行函數,函數調用和函數執行時一個意思,要真有個區別
函數調用是傳遞實際參數給函數,函數執行時執行函數體
4. return 語句從函數中返回結果值,也就是函數的輸出,能夠時一個值,也能夠時多個值,若是沒有return語句則函數返回 None編輯器
def compare(one, two): """比較兩個字符串,忽略大小寫 若是同樣則返回True, 不然返回False""" res = one.lower() == two.lower() return res str_one = "123XXX" str_two = "123xxx" # 比較兩個字符串是否一致 res = compare(str_one, str_two) print(res)
形參 和 實參函數
形參
函數定義時候使用,只存在名稱,沒有具體的值,但能夠在函數體內參與運算,很特殊,相似數學中的代數運算學習
實參
函數調用時候使用,須要傳遞具體的值給函數定義的形參spa
函數調用過程中傳遞參數的幾種方式
1. 位置參數,經過實參索引位置與形參索引位置依次賦值,等價於多重賦值
2. 關鍵字參數,經過形參名稱指定實參值的形式
3. 解包序列提供位置參數,解包字典提供關鍵字參數對象
def compare(one, two): """比較兩個字符串,忽略大小寫 若是同樣則返回True, 不然返回False""" res = one.lower() == two.lower() return res str_list = ["123XXX", "123xxx"] # 解包序列獲取位置參數,要求序列中元素個數必須和函數定義的位置參數個數如出一轍 res = compare(*str_list) print(res) str_dict = { "one": "123XXX", "two": "123xxx" } # 解包字典獲取關鍵字參數,要求字典中的key要和函數定義的形參名稱一一對應 res = compare(**str_dict) print(res)
函數定義中形參的幾種形式blog
# 形參的定義控制函數調用時候參數的傳遞方式
1. 必傳參數
2. 默認參數,在函數定義過程當中計算的,只會執行一次,這對形參默認值時時可變類型時候顯得重要
3. 可變參數(又叫收集參數、非固定參數)
4. 僅限位置參數、僅限關鍵字參數、位置或關鍵字參數索引
def beg_sum(one, two, *num, **kwargs): """對兩數求和,若是、num有則加上num中數""" res = one + two if not num: return res res += sum(num) # 輸出kwars參數 print(kwargs) return res # 經過位置參數傳遞參數 res = beg_sum(1, 3, 77, 99, 99) print(res) # 經過關鍵字參數傳遞參數 res = beg_sum(one=1, two=2, three=4) print(res)
細心觀察函數,你會發現,函數就是一個架子(框架),定義了輸入,也定義了輸出,至於中間的函數邏輯須要根據
具體的業務場景寫語句邏輯
函數的語法糖形式又稱爲匿名函數
# lambda 表達式,返回的時函數對象,主要用於一些內置的函數,如 map reduce filter sort
# 應用於對可迭代對象中元素的簡單處理
# lambda 表達式只限於單行表達式
# lambda 函數並特殊,只是普通def函數的簡寫,一種語法上的便捷,就好像吃了糖同樣,甜甜的,全部叫作語法糖
nums = [10, 2, 3, 4, 6, 7, 8] # 過濾掉 小於等於3的 want_nums = filter(lambda x: x > 3, nums) print(list(want_nums))
函數標註
# 參數和返回值的元信息,相似靜態語言的參數的類型與返回值類型,但不一樣的是Python的標註信息僅僅是提示,不作
參數類型檢查,保存在函數元信息的 __annotations__以字典形式存放
def compare(one: str, two: str) -> int: """比較兩個字符串,忽略大小寫 若是同樣則返回True, 不然返回False""" res = one.lower() == two.lower() return res str_one = "123XXX" str_two = "123xxx" # 比較兩個字符串是否一致 res = compare(str_one, str_two) print(res) # 打印函數元信息,函數標註 print(compare.__annotations__)
全部名稱遵照一樣的規範
# [a-zA-Z][a-zA-Z0-9]*
# 基本上都是英文單詞和英文單詞的縮寫或簡寫
# 不能是關鍵字或內置函數名稱
聲明 = 定義 = 建立
元數據 任何數據都有元數據
對數據的特徵描敘,又叫元信息
例如數字 1 其元數據:
a. int類型
b. 支持數值運算 + - * / // %
c. 邏輯值爲真
... 具備意義的特徵信息
小明 元數據
身高
體重
年齡
學歷
...
Python 中並不存在變量聲明這麼一說,只存在變量賦值
形式 varname = expression
# 等號左邊的是變量賦值,會首先查找當前做用域中的變量,若是沒找到,則新建一個變量varname,若是找到則修改其值
# 可是在 expression 中的變量,更確切的說是參與表達式運算的變量,這就存在變量引用,這個變量引用會首先找當前局部做用域中該行語句以前建立的變量,若是沒有找到,則找外一層的局部變量,依次往上找,並不會往下找,一直找到全局變量,也就是定義在模塊中的變量,還找不到則去找內置名稱
# expression 中變量,稱爲變量引用,變量引用的查找過程 當前做用域 > 外層函數的做用域 > 全局做用域 > 內置名稱, 只要在某一級找到,則中止查找返回確切的值
# Python中也不存在常量這麼概念,咱們能夠約定變量名大寫就是語義上實現常量
構成做用域的在Python中只要函數、模塊、內置名稱、類