首先說一下函數的定義:
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