第三章 函数编程
函數是一段具有特定功能的、可重用的語句組,用函數名來表示并通過函數名進行功能調用。函數也可以看作是一段具有名字的子程序
特性:
1.減少重復代碼
2.使程序變的可擴展
3.使程序變得易維護
語法定義
def sayhi():#函數名print("Hello, I'm nobody!") sayhi() #調用函數可以帶參數
def calc(x,y):res = x**yreturn res #返回函數執行結果 c = calc(a,b) #結果賦值給c變量 print(c)參數可以讓你的函數更靈活,不只能做死的動作,還可以根據調用時傳參的不同來決定函數內部的執行流程
函數參數
形參變量
只有在被調用時才分配內存單元,在調用結束時,即刻釋放所分配的內存單元。因此,形參只在函數內部有效。函數調用結束返回主調用函數后則不能再使用該形參變量
實參
可以是常量、變量、表達式、函數等,無論實參是何種類型的量,在進行函數調用時,它們都必須有確定的值,以便把這些值傳送給形參。因此應預先給實參賦值
默認參數
看如下代碼
def stu_register(name,age,country,course):print("----注冊學生信息------")print("姓名:",name)print("age:",age)print("國籍:",country)print("課程:",course) stu_register("王山炮",22,"CN","python_devops") stu_register("張叫春",21,"CN","linux") stu_register("劉老根",25,"CN","linux")發現 country 這個參數 基本都 是”CN”, 就像我們在網站上注冊用戶,像國籍這種信息,你不填寫,默認就會是 中國, 這就是通過默認參數實現的,把country變成默認參數非常簡單
def stu_register(name,age,course,country="CN"):這樣,這個參數在調用時不指定,那默認就是CN,指定了的話,就用你指定的值。
另外,你可能注意到了,在把country變成默認參數后,我同時把它的位置移到了最后面,為什么呢?
關鍵參數
正常情況下,給函數傳參數要按順序,不想按順序就可以用關鍵參數,只需指定參數名即可(指定了參數名的參數就叫關鍵參數),但記住一個要求就是,關鍵參數必須放在位置參數(以位置順序確定對應關系的參數)之后
def stu_register(name, age, course='PY' ,country='CN'):print("----注冊學生信息------")print("姓名:", name)print("age:", age)print("國籍:", country)print("課程:", course)調用可以這樣
stu_register("王山炮",course='PY', age=22,country='JP' )但絕不可以這樣
stu_register("王山炮",course='PY',22,country='JP' )當然這樣也不行
stu_register("王山炮",22,age=25,country='JP' )這樣相當于給age賦值2次,會報錯!
注意,參數優先級順序是 位置參數>關鍵參數
非固定參數
若你的函數在定義時不確定用戶想傳入多少個參數,就可以使用非固定參數
def stu_register(name,age,*args): # *args 會把多傳入的參數變成一個元組形式print(name,age,args) stu_register("Alex",22) #輸出 #Alex 22 () #后面這個()就是args,只是因為沒傳值,所以為空 stu_register("Jack",32,"CN","Python") #輸出 # Jack 32 ('CN', 'Python')還可以有一個**kwargs
def stu_register(name,age,*args,**kwargs): # *kwargs 會把多傳入的參數變成一個dict形式print(name,age,args,kwargs) stu_register("Alex",22) #輸出 #Alex 22 () {}#后面這個{}就是kwargs,只是因為沒傳值,所以為空 stu_register("Jack",32,"CN","Python",sex="Male",province="ShanDong") #輸出 # Jack 32 ('CN', 'Python') {'province': 'ShanDong', 'sex': 'Male'}?深淺copy
dict ,list,set
s = {name:alex....}
s2 = a ,此時s2和s是共享的同一份數據的
copy一份數據
淺copy,只copy第一層
s2 =? s.copy
深copy? ?copy多層(import copy)
# coding=utf-8 # s = {} # print(s) # 列表、字典,集合都有copy方法s = {"name":"alex","age":18,"scores":{"語文":130,"數學":60,"英語":98,} } print(s) s2 = s print(s2) print(id(s)) print(id(s2)) s2["name"] = "金角大王" print(s) print(s2) s3 = s.copy() print(s3) s3["name"] = "黑姑娘" print(s3) print(s2) print(s) print(s3["scores"]["語文"]) s3["scores"]["語文"] = 29 print(s3) print(s2) print(s) import copy s4 = copy.deepcopy(s) # 深copy print(s4) s4["scores"]["語文"] = 10 print(s4) print(s) 《新程序員》:云原生和全面數字化實踐50位技術專家共同創作,文字、視頻、音頻交互閱讀總結
- 上一篇: 第二章 数据类型和文件操作
- 下一篇: 第四章 常用模块