python之函數詳解(匿名函數,缺省函數,內置函數,冗餘參數)

首先說一下函數的定義:
def 函數名(參數列表):
函數體
***1、如果在定義函數的時候,函數名有兩個或者以上單詞組成的時候,第二個單詞的首字母要大寫,這就和類裏面的方法有一致的規則*。
***2、在函數定義的時候,如果定義了幾個參數,那麼在調用函數的時候,就要把幾個參數傳給函數。就是要不多不少。*
否則:

>>> def test(a,b):
    print a*b

>>> test()

Traceback (most recent call last):
  File "<pyshell#28>", line 1, in <module>
    test()
TypeError: test() takes exactly 2 arguments (0 given)
>>> test(3,4)
12
>>> 
形參和實參要一一對應

3、缺省參數(默認參數)
我們還是來看上面的例子:給它定義默認參數

>>> def test(a,b=4):
    print a*b


>>> test(8)
32
>>> def test(a=6,b=7):
    print a*b   
>>> test()
42

如果在有默認參

數的情況下,我們給定參數的話,還是實參,形參一一對應的。

>>> test(7)
49

那這樣的話我想使用默認的a,b的值自己給,就是下面這樣:

>>> test(b=5)
30

注意:設置默認參數的時候一定是自右向左的。例如:

>>> def test(a=6,b)
SyntaxError: invalid syntax

就像上面這樣的定義就是語法錯誤,設置默認參數一定要自右向左。
4、函數變量作用域
全局變量和局部變量,這兩個很簡單不用說了,要說的一點就是:
將局部變量強制變爲全局變量,就下面這條語句:
global 局部變量名
5、函數的多類型傳值:
5.1 元組類型參數:

>>> abc=(1,2,3,"hello")
>>> abc
(1, 2, 3, 'hello')
首

先定義了一個元組

>>> def ll(x,y,z,s):
    print "num1 : %d ,num2 : %d, num3 : %d, string: %s" %(x,y,z,s)

定義一個函數,輸出三個數字和一個字符串

>>> ll(2,3,4,"ok")
num1 : 2 ,num2 : 3, num3 : 4, string: ok
>>> 
>>> ll(abc)

Traceback (most recent call last):
  File "<pyshell#183>", line 1, in <module>
    ll(abc)
TypeError: ll() takes exactly 4 arguments (1 given)
>>> 
>>> ll(*abc)
num1 : 1 ,num2 : 2, num3 : 3, string: hello
通過上面的代碼可以看

到,如果函數的參數和元組的內容是一一對應的話,我們就可以通過*元組名 來傳遞參數。
但是如果元組的內容個數和函數參數的個數不匹配的話,請看下面的例子:

>>> abcd=(1,2,3,4,"hello")
>>> ll(*abcd)

Traceback (most recent call last):
  File "<pyshell#187>", line 1, in <module>
    ll(*abcd)
TypeError: ll() takes exactly 4 arguments (5 given)
就會出現上

面參數不匹配的錯誤
5.2 字典形式參數:

>>> def info(name="liang",age=22,height=180):
    print "name:%s , age %d , height %d" % (name,age,height)


>>> info()
name:liang , age 22 , height 180
>>> info("tom",24,190)
name:tom , age 24 , height 190

我們可以看到


:在上面就定義了一個函數,函數體就是輸出傳值進去的字典,
>>> x={'name':"Bryant",'age':24,'height':198}
>>> info(**x)
name:Bryant , age 24 , height 198
然後我們再

定義了一個字典,通過兩個*字典名 把字典的值傳值給函數。
因爲字典是無序的,所以我們按下面的這樣也是可以的:

>>> x={'height':198,'age':24,'name':"Bryant"}
>>> info(**x)
name:Bryant , age 24 , height 198

這裏要說的是,上面的元組傳值需要的是一個星號,而字典傳值是需要兩個星號,因爲字典包括key和value兩部分
當字典的值改變的話,函數的輸出也會相應的變化:

>>> x['age']=30
>>> info(**x)
name:Bryant , age 30 , height 198

要注意的是字典裏面的鍵值一定是函數參數裏面有的,不然就會出錯:

>>> x={'h':199,'a':30,'n':"Bryant"}
>>> info(**x)

Traceback (most recent call last):
  File "<pyshell#214>", line 1, in <module>
    info(**x)
TypeError: info() got an unexpected keyword argument 'a'

但是我們經常在程序裏就沒那麼好了,可能常常就是不一樣的。我們可以使用下面的這樣來實現:

>>> info(x['n'],x['a'],x['h'])
name:Bryant , age 30 , height 199

6、處理多餘的冗餘實參:

>>> def f(x,*args):
    print x
    print args


>>> f(1)
1
()
>>> f(1,2,3)
1
(2, 3)

首先我們定義一個函數,這個函數的形參有個*args,就表示利用args這個元組來接受函數多餘的實參,我們可以看到函數給定的實參爲1,2,3的時候,函數把多餘的2和3保存在了元組裏面。
當給函數傳的值爲有映射關係的值時,就要用到字典格式來接受多餘的參數了,不然會出現下面錯誤:

>>> f(x=3,y=4)

Traceback (most recent call last):
  File "<pyshell#6>", line 1, in <module>
    f(x=3,y=4)
TypeError: f() got an unexpected keyword argument 'y'

所以我們這樣修改:

>>> def f(x,*args,**kwargs):
    print x
    print args
    print kwargs


>>> f(1,2,3,4,5)
1
(2, 3, 4, 5)
{}
>>> f(1,2,3,4,5,name='Bryant')
1
(2, 3, 4, 5)
{'name': 'Bryant'}
>>> f(1,2,3,4,5,name='Bryant',age=36)
1
(2, 3, 4, 5)
{'age': 36, 'name': 'Bryant'}
>>> 

在此要說明的是,多用return 而少用print,除非你需要用到在屏幕上輸出。
7、lambda匿名函數

>>> def ff(x,y):
    return x*y

>>> g =ff(2,3)
>>> g
6
>>> gg=lambda x,y : x*y
>>> gg(2,3)
6

通過上面的代碼可以看到, gg=lambda x,y : x*y 這一條匿名函數的定義語句就完成了上面函數的整個定義,lambda實際上就是構建了一個函數對象,然後將這個對象賦值給gg,就相當於函數裏面的return語句。

我們使用reduce函數以及匿名函數來計算一個數的階乘:

>>> l=range(1,9)
>>> def f(x,y):
    return x*y

>>> reduce(f,l)
40320
>>> reduce (lambda x,y:x*y,range(1,7))
720
>>> reduce (lambda x,y:x*y,range(1,9))
40320

就像這樣可以實現一條語句就算出一個數字的階乘,重點是如果像計算階乘等這樣的函數被調用的次數不多,就通過這樣來省去繁複的函數定義,減少代碼量。
8、Python常見的內置函數:

一、數學運算類

abs(x) 求絕對值
1、參數可以是整型,也可以是複數
2、若參數是複數,則返回複數的模
complex([real[, imag]]) 創建一個複數
divmod(a, b) 分別取商和餘數
注意:整型、浮點型都可以
float([x]) 將一個字符串或數轉換爲浮點數。如果無參數將返回0.0
int([x[, base]]) 將一個字符轉換爲int類型,base表示進制
long([x[, base]]) 將一個字符轉換爲long類型
pow(x, y[, z]) 返回x的y次冪
range([start], stop[, step]) 產生一個序列,默認從0開始
round(x[, n]) 四捨五入
sum(iterable[, start]) 對集合求和
oct(x) 將一個數字轉化爲8進制
hex(x) 將整數x轉換爲16進制字符串
chr(i) 返回整數i對應的ASCII字符
bin(x) 將整數x轉換爲二進制字符串
bool([x]) 將x轉換爲Boolean類型

二、集合類操作

basestring() str和unicode的超類
不能直接調用,可以用作isinstance判斷
format(value [, format_spec]) 格式化輸出字符串
格式化的參數順序從0開始,如“I am {0},I like {1}”
unichr(i) 返回給定int類型的unicode
enumerate(sequence [, start = 0]) 返回一個可枚舉的對象,該對象的next()方法將返回一個tuple
iter(o[, sentinel]) 生成一個對象的迭代器,第二個參數表示分隔符
max(iterable[, args…][key]) 返回集合中的最大值
min(iterable[, args…][key]) 返回集合中的最小值
dict([arg]) 創建數據字典
list([iterable]) 將一個集合類轉換爲另外一個集合類
set() set對象實例化
frozenset([iterable]) 產生一個不可變的set
str([object]) 轉換爲string類型
sorted(iterable[, cmp[, key[, reverse]]]) 隊集合排序
tuple([iterable]) 生成一個tuple類型
xrange([start], stop[, step]) xrange()函數與range()類似,但xrnage()並不創建列表,而是返回一個xrange對象,它的行爲與列表相似,但是隻在需要時才計算列表值,當列表很大時,這個特性能爲我們節省內存

三、邏輯判斷

all(iterable) 1、集合中的元素都爲真的時候爲真
2、特別的,若爲空串返回爲True
any(iterable) 1、集合中的元素有一個爲真的時候爲真
2、特別的,若爲空串返回爲False
cmp(x, y) 如果x < y ,返回負數;x == y, 返回0;x > y,返回正數

四、反射

callable(object) 檢查對象object是否可調用
1、類是可以被調用的
2、實例是不可以被調用的,除非類中聲明瞭call方法
classmethod() 1、註解,用來說明這個方式是個類方法
2、類方法即可被類調用,也可以被實例調用
3、類方法類似於Java中的static方法
4、類方法中不需要有self參數

compile(source, filename,

mode[, flags[, dont_inherit]])
將source編譯爲代碼或者AST對象。代碼對象能夠通過exec語句來執行或者eval()進行求值。
1、參數source:字符串或者AST(Abstract Syntax Trees)對象。
2、參數 filename:代碼文件名稱,如果不是從文件讀取代碼則傳遞一些可辨認的值。
3、參數model:指定編譯代碼的種類。可以指定爲 ‘exec’,’eval’,’single’。
4、參數flag和dont_inherit:這兩個參數暫不介紹
dir([object]) 1、不帶參數時,返回當前範圍內的變量、方法和定義的類型列表;
2、帶參數時,返回參數的屬性、方法列表。
3、如果參數包含方法dir(),該方法將被調用。當參數爲實例時。
4、如果參數不包含dir(),該方法將最大限度地收集參數信息
delattr(object, name) 刪除object對象名爲name的屬性
eval(expression [, globals [, locals]]) 計算表達式expression的值
execfile(filename [, globals [, locals]]) 用法類似exec(),不同的是execfile的參數filename爲文件名,而exec的參數爲字符串。
filter(function, iterable) 構造一個序列,等價於[ item for item in iterable if function(item)]
1、參數function:返回值爲True或False的函數,可以爲None
2、參數iterable:序列或可迭代對象
getattr(object, name [, defalut]) 獲取一個類的屬性
globals() 返回一個描述當前全局符號表的字典
hasattr(object, name) 判斷對象object是否包含名爲name的特性
hash(object) 如果對象object爲哈希表類型,返回對象object的哈希值
id(object) 返回對象的唯一標識
isinstance(object, classinfo) 判斷object是否是class的實例
issubclass(class, classinfo) 判斷是否是子類
len(s) 返回集合長度
locals() 返回當前的變量列表
map(function, iterable, …) 遍歷每個元素,執行function操作
memoryview(obj) 返回一個內存鏡像類型的對象
next(iterator[, default]) 類似於iterator.next()
object() 基類
property([fget[, fset[, fdel[, doc]]]]) 屬性訪問的包裝類,設置後可以通過c.x=value等來訪問setter和getter
reduce(function, iterable[, initializer]) 合併操作,從第一個開始是前兩個參數,然後是前兩個的結果與第三個合併進行處理,以此類推
reload(module) 重新加載模塊
setattr(object, name, value) 設置屬性值
repr(object) 將一個對象變幻爲可打印的格式
slice()  
staticmethod 聲明靜態方法,是個註解
super(type[, object-or-type]) 引用父類
type(object) 返回該object的類型
vars([object]) 返回對象的變量,若無參數與dict()方法類似
bytearray([source [, encoding [, errors]]]) 返回一個byte數組
1、如果source爲整數,則返回一個長度爲source的初始化數組;
2、如果source爲字符串,則按照指定的encoding將字符串轉換爲字節序列;
3、如果source爲可迭代類型,則元素必須爲[0 ,255]中的整數;
4、如果source爲與buffer接口一致的對象,則此對象也可以被用於初始化bytearray.
zip([iterable, …]) 實在是沒有看懂,只是看到了矩陣的變幻方面

五、IO操作

file(filename [, mode [, bufsize]]) file類型的構造函數,作用爲打開一個文件,如果文件不存在且mode爲寫或追加時,文件將被創建。添加‘b’到mode參數中,將對文件以二進制形式操作。添加‘+’到mode參數中,將允許對文件同時進行讀寫操作
1、參數filename:文件名稱。
2、參數mode:’r’(讀)、’w’(寫)、’a’(追加)。
3、參數bufsize:如果爲0表示不進行緩衝,如果爲1表示進行行緩衝,如果是一個大於1的數表示緩衝區的大小 。
input([prompt]) 獲取用戶輸入
推薦使用raw_input,因爲該函數將不會捕獲用戶的錯誤輸入
open(name[, mode[, buffering]]) 打開文件
與file有什麼不同?推薦使用open
print 打印函數
raw_input([prompt]) 設置輸入,輸入都是作爲字符串處理

六、其他

help()–幫助信息
比如說我們不知道一個內置函數的用法就可以這樣來查看:

>>> help(abs)
Help on built-in function abs in module __builtin__:

abs(...)
    abs(number) -> number

    Return the absolute value of the argument.

>>> 

七、後記

內置函數,一般都是因爲使用頻率比較頻繁或是是元操作,所以通過內置函數的形式提供出來,通過對python的內置函數分類分析可以看出來:基本的數據操作基本都是一些數學運算(當然除了加減乘除)、邏輯操作、集合操作、基本IO操作,然後就是對於語言自身的反射操作,還有就是字符串操作,也是比較常用的,尤其需要注意的是反射操作

在這裏可以先看看常用的內置函數用法:
處理序列:
filter()
zip()
map()
reduce()
處理字符串:下面列出了常用的python實現的字符串操作

1.複製字符串

strcpy(sStr1,sStr2)

sStr1 = ‘strcpy’
sStr2 = sStr1
sStr1 = ‘strcpy2’
print sStr2

2.連接字符串

strcat(sStr1,sStr2)

sStr1 = ‘strcat’
sStr2 = ‘append’
sStr1 += sStr2
print sStr1

3.查找字符

strchr(sStr1,sStr2)

sStr1 = ‘strchr’
sStr2 = ‘r’
nPos = sStr1.index(sStr2)
print nPos

4.比較字符串

strcmp(sStr1,sStr2)

sStr1 = ‘strchr’
sStr2 = ‘strch’
print cmp(sStr1,sStr2)

5.掃描字符串是否包含指定的字符

strspn(sStr1,sStr2)

sStr1 = ‘12345678’
sStr2 = ‘456’

sStr1 and chars both in sStr1 and sStr2

print len(sStr1 and sStr2)

6.字符串長度

strlen(sStr1)

sStr1 = ‘strlen’
print len(sStr1)

7.將字符串中的小寫字符轉換爲大寫字符

strlwr(sStr1)

sStr1 = ‘JCstrlwr’
sStr1 = sStr1.upper()
print sStr1

8.追加指定長度的字符串

strncat(sStr1,sStr2,n)

sStr1 = ‘12345’
sStr2 = ‘abcdef’
n = 3
sStr1 += sStr2[0:n]
print sStr1

9.字符串指定長度比較

strncmp(sStr1,sStr2,n)

sStr1 = ‘12345’
sStr2 = ‘123bc’
n = 3
print cmp(sStr1[0:n],sStr2[0:n])

10.複製指定長度的字符

strncpy(sStr1,sStr2,n)

sStr1 = ”
sStr2 = ‘12345’
n = 3
sStr1 = sStr2[0:n]
print sStr1

11.字符串比較,不區分大小寫

stricmp(sStr1,sStr2)

sStr1 = ‘abcefg’
sStr2 = ‘ABCEFG’
print cmp(sStr1.upper(),sStr2.upper())

12.將字符串前n個字符替換爲指定的字符

strnset(sStr1,ch,n)

sStr1 = ‘12345’
ch = ‘r’
n = 3
sStr1 = n * ch + sStr1[3:]
print sStr1

13.掃描字符串

strpbrk(sStr1,sStr2)

sStr1 = ‘cekjgdklab’
sStr2 = ‘gka’
nPos = -1
for c in sStr1:
if c in sStr2:
nPos = sStr1.index(c)
break
print nPos

14.翻轉字符串

strrev(sStr1)

sStr1 = ‘abcdefg’
sStr1 = sStr1[::-1]
print sStr1

15.查找字符串

python strstr

strstr(sStr1,sStr2)

sStr1 = ‘abcdefg’
sStr2 = ‘cde’
print sStr1.find(sStr2)

16.分割字符串

strtok(sStr1,sStr2)

sStr1 = ‘ab,cde,fgh,ijk’
sStr2 = ‘,’
sStr1 = sStr1[sStr1.find(sStr2) + 1:]
print sStr1

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章