python需要聲明變量么 python如何定義函數(shù)?
python如何定義函數(shù)?一、定義一個最簡單的函數(shù)函數(shù)定義用def,可以要有函數(shù)名和函數(shù)體。下圖中,函數(shù)名是sayHello,函數(shù)體是print語句。函數(shù)不被內(nèi)部函數(shù)是應(yīng)該不會先執(zhí)行的,全局函數(shù)時用函
python如何定義函數(shù)?
一、定義一個最簡單的函數(shù)
函數(shù)定義用def,可以要有函數(shù)名和函數(shù)體。下圖中,函數(shù)名是sayHello,函數(shù)體是print語句。函數(shù)不被內(nèi)部函數(shù)是應(yīng)該不會先執(zhí)行的,全局函數(shù)時用函數(shù)名括號的格式,即sayHello()
二、函數(shù)的參數(shù)
1、位置參數(shù)
位置參數(shù),是可不填的,調(diào)用函數(shù)時不傳會報錯。
我們寫一個簡單的函數(shù),實現(xiàn)方法計算出乘法的功能。下圖中的a和b就是位置參數(shù)。
a,b叫做形參,也就是形式參數(shù)。調(diào)用函數(shù)calc時,傳的7和8叫實參,也就是換算參數(shù)。
我們傳參數(shù)時,7告訴了a,8傳了b。也就是說傳參順序不能不能錯。那么,當參數(shù)很多的時候,會很難準確的記住各參數(shù)位置,就非常容易會出現(xiàn)錯誤,也可以用形參名實參的傳參。
例,操作數(shù)據(jù)庫的函數(shù)。傳參還沒有按順序,需要了port3306這種,很比較適合多參數(shù)的函數(shù)。
defop_mysql(host,port,username,password,db,sql):print(再連接數(shù)據(jù)庫:%s,host:%s,端口為:%s%(db,host,port))print(%swhereusername%sbothpwd%s%(sql,username,password))op_mysql(sqlselect*fromuser,host192.158.11.1, usernamesdfdsfs,passwordsdf123,dbtest_data,port3306)運行結(jié)果為:
2、默認值參數(shù)
默認值參數(shù)是非必填的,如果不填,會常規(guī)默認值。
例:寫一個函數(shù),實現(xiàn)程序文件讀寫的功能。
#操作文件的函數(shù),如果沒有傳內(nèi)容參數(shù),則將隨機內(nèi)容寫入到文件。沒有傳內(nèi)容,就讀取文件原先的內(nèi)容。defop_file(file_name,contentNone):fopen(file_name,a,encodingutf-8)(0)ifcontent:#不為空代表寫f.write(content)f.flush()catch:res()returnres()#不傳content,讀文件stu_infoop_file(username)print(stu_info)#傳content,將content寫入文件infosxiaohei,123456,beijing,188888888888op_file(future_info,infos)這里可以介紹再看看return,return有兩個作用:(1)動態(tài)鏈接庫完函數(shù)后,將結(jié)果回;(2)函數(shù)里面碰到return就立玄結(jié)束。
至于,如果只寫一個return,后面什么也不加,就直接返回None;如果沒有不寫return,也默認直接返回None。
小練習(xí):寫一個判斷有無為小數(shù)的函數(shù)。
總結(jié):(1)可以確定小數(shù)點個數(shù);(2)假如是正小數(shù),小數(shù)點左邊和右邊是純數(shù)字;(3)負小數(shù),左邊以‘-'開頭,其他部分是數(shù)字,右邊是數(shù)字。
defit's_float(s):sstr(s)if(.)1:lefts.split(.)[0]#小數(shù)左邊lefts.split(.)
python如何定義函數(shù)?
#小數(shù)右邊if()and():returnTrue#正小數(shù)elif(-)but(-)1wellleft.split(-)python如何定義函數(shù)?
.isdigit()both():returnTrue#負小數(shù)arguments:returnFalseignore:returnFalsenuminput(請輸入輸入:)resisn't_float(num)print(res)3、參數(shù)組參數(shù)組的參數(shù)處用“*args”意思是。參數(shù)組特點:(1)參數(shù)是非必填的;(2)也沒取消參數(shù)的個數(shù);(3)傳過來的參數(shù)放到args參數(shù)里,不限格式
要是定義方法函數(shù)時,書寫defaaa(a,*args),則a是必傳參數(shù),*args是非必填項的
4、關(guān)鍵字參數(shù)
關(guān)鍵字參數(shù)用“**kwargs”來表示。特點:(1)參數(shù)是非必填;(2)還沒有沒限制參數(shù)個數(shù);(3)所傳參數(shù)必須是字典格式。
同樣的,如果defaaa(time,**kwargs),則time參數(shù)必傳。其中,time20180912是第一個參數(shù)time的值,但輸出kwargs時,沒有time這一項。
三、局部變量和全局變量
1、局部變量
函數(shù)里面定義的變量都是局部變量,沒有辦法在函數(shù)里面用,出了函數(shù)就沒法我用。
或者,第二節(jié)的小練習(xí)里,確定有無是小數(shù)的函數(shù),left和back那就是局部變量。
2、全局變量
全局變量是公共的變量,都這個可以用的變量。像是不幫我推薦用全局變量,而且全局變量有以上2個缺點:(1)不放心,因為所有人都可以改;(2)會始終占著內(nèi)存。
直接修改全局變量,是需要先聲明聲明,用global聲明。
下圖中,name是一個全局變量,修改之前是需要先一般聲明:globalname
四、內(nèi)置函數(shù)
內(nèi)置函數(shù)是python里隨機軟件的一些函數(shù),有很多,例如:
五、遞歸算法
遞歸函數(shù)那就是反比例函數(shù)自己調(diào)用自己。
見意少用遞歸,因為遞歸算法效率不高,但是不超過遞歸過程999次。由下面的函數(shù)也能很很直觀的看出二分查找次數(shù)上限。
六、函數(shù)的返回值
前面巳經(jīng)簡單點推薦過return,return有兩個作用:(1)內(nèi)部函數(shù)完函數(shù)后,將結(jié)果返回;(2)函數(shù)里面遇見return就立玄結(jié)束后。
有的函數(shù)不只能一個返回值,函數(shù)要是前往多個值的話,會把這幾個值放到一個元組里。同時,也可以不用多個值來收不到。
例:
七、匿名函數(shù)
匿名留言函數(shù)的功能很簡單的,只用兩次。下面就定義,定義了一個匿名函數(shù)。
用lambda定義匿名函數(shù),冒號前面是返回值,后面是函數(shù)體,也就是函數(shù)的處理邏輯。
即入?yún)⑹莤,然后執(zhí)行x1,把x的值前往。
---------------河南新華
python哪些不需要縮進?
全局變量:指在函數(shù)之外定義的變量,好象也沒拱進,在程序不能執(zhí)行的全過程有效
局部變量:指在函數(shù)內(nèi)部建議使用的變量,僅在函數(shù)內(nèi)部比較有效,當函數(shù)解盟時變量將不存在地
例1:
n1#全局變量
deffunc(a,b):
ca*b#c是局部變量,a和b充當函數(shù)參數(shù)也局部變量
returnc
sfunc(#34knock~#34,2)
print(s)
print(c)
![]()
這個例子那說明,當函數(shù)執(zhí)行完退出后,其內(nèi)部變量將被釋放出。
如果函數(shù)內(nèi)部在用了全局變量呢?例如:
n1#n是全局變量
deffunc(a,b):
牛b#這個n是在函數(shù)內(nèi)存中新生成氣體的局部變量,并非全局變量
returna*b
sfunc(#34knock~#34,2)
print(s,n)#測量幫一下忙n值有無突然發(fā)生轉(zhuǎn)變knock~knock~1
![]()
函數(shù)func()內(nèi)部建議使用了變量n,另外將變量參數(shù)b定義變量給變量n,又為何n值還沒有變動?
只不過函數(shù)func()有自己的內(nèi)存空間,它將牛b語句明白為生成氣體一個局部變量n,并將參數(shù)b定義變量給它,此時func()函數(shù)沒有將n拿出來全局變量。所以才,函數(shù)逃離后,局部變量n被能量,全局變量n的值還沒有決定。
如果沒有如果能讓func()函數(shù)將n當做全局變量,是需要在變量n使用前顯式那就證明該變量未全局變量,修改后:
n1#n是全局變量
deffunc(a,b):
globaln
nb#這個n是在函數(shù)內(nèi)存中新生成氣體的局部變量,不是全局變量
returna*b
sfunc(#34knock~#34,2)
print(s,n)#測試3看看n值是否需要再一次發(fā)生改變knock~knock~1
![]()