国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > Python > 正文

收藏整理的一些Python常用方法和技巧

2019-11-25 17:27:29
字體:
來源:轉載
供稿:網友

1. 逆轉字符串的三種方法
1.1. 模擬C++中方法, 定義一個空字符串來實現
通過設置一個空字符串, 然后講參數中的字符串從后往前遍歷, 使用字符串的加法合并為新的字符串

復制代碼 代碼如下:

def reverse(text) :
    str = ''
    index = len(text) - 1
    while index >= 0 :
        str += text[index]
        index -= 1
    return str

1.2. 使用切片法
這個是Python中的一個特性, 切片可以取負值,這是采用切片的方法,設置步長為-1,這樣就實現了反過來排序。
復制代碼 代碼如下:

def reverse_1(text) :
    return text[::-1]

1.3. 使用列表

采用列表的reverse方法,先將text轉換為列表,然后通過reverse方法反轉,然后在通過join連接為字符串。

復制代碼 代碼如下:

def reverse_2(text) :
    temp = list(text)
    temp.reverse()
    return ''.join(temp)

2. 使用reduce
使用匿名函數和reduce()
復制代碼 代碼如下:

def reverse_3(text) :
    return reduce(lambda x, y : y + x, text)
print reverse_3("Hello")

3. 遍歷字典的四種方法

復制代碼 代碼如下:

dict={"a":"apple","b":"banana","o":"orange"}
 
print "##########dict######################"
for i in dict:
        print "dict[%s]=" % i,dict[i]
 
print "###########items#####################"
for (k,v) in  dict.items():
        print "dict[%s]=" % k,v
 
print "###########iteritems#################"
for k,v in dict.iteritems():
        print "dict[%s]=" % k,v
 
print "###########iterkeys,itervalues#######"
for k,v in zip(dict.iterkeys(),dict.itervalues()):
        print "dict[%s]=" % k,v

4. 遍歷list的三種方法
復制代碼 代碼如下:

for key in lst :
    print key
   
for i in range(len(lst)) :
    print lst[i]
for index, key in enumerate(lst) :
    print key    //index是list的索引

5. 字典排序的方法
字典按照value的值從大到小的順序來排序(默認從小到排序)。
復制代碼 代碼如下:

dic = {'a':31, 'bc':5, 'c':3, 'asd':4, 'aa':74, 'd':0}
dict= sorted(dic.iteritems(), key=lambda d:d[1], reverse = True)
print dict
//輸出的結果:
[('aa', 74), ('a', 31), ('bc', 5), ('asd', 4), ('c', 3), ('d', 0)]

下面我們分解下代碼
print dic.iteritems() 得到[(鍵,值)]的列表。
然后用sorted方法,通過key這個參數,指定排序是按照value,也就是第一個元素d[1的值來排序。reverse = True表示是需要翻轉的,默認是從小到大,翻轉的話,那就是從大到小。
對字典按鍵(key)排序:

復制代碼 代碼如下:

dic = {'a':31, 'bc':5, 'c':3, 'asd':4, 'aa':74, 'd':0}
dict= sorted(dic.iteritems(), key=lambda d:d[0]) # d[0]表示字典的鍵
print dict
#sorted中第三個可選參數為reverse, True表示從大到小排序
#默認reverse = False

6. 子類和父類
子類構造函數調用父類的初始化構造函數

復制代碼 代碼如下:

class A(object) :
    def __init__(self) :
        print  "testA
class B(A) :
    def __init__(self) :
        A.__init__(self)

子類調用父類的同名函數
復制代碼 代碼如下:

super().fuleifunction()

7. 更靈活的參數傳遞方式
復制代碼 代碼如下:

func2(a=1, b=2, c=3) #默認參數
func3(*args)         #接受任意數量的參數, 以tuple的方式傳入
func4(**kargs)       #把參數以鍵值對字典的形式傳入

在變量前加上星號前綴(*),調用時的參數會存儲在一個 tuple()對象中,賦值給形參。在函數內部,需要對參數進行處理時,只要對這個 tuple 類型的形參(這里是 args)進行操作就可以了。因此,函數在定義時并不需要指明參數個數,就可以處理任意參數個數的情況。

復制代碼 代碼如下:

def calcSum(*args):
    sum = 0
    for i in args:
        sum += i
        print sum
#調用:
calcSum(1,2,3)
calcSum(123,456)
calcSum()
#輸出:
6
579
0
#################################
def printAll(**kargs):
    for k in kargs:
    print k, ':', kargs[k]
printAll(a=1, b=2, c=3)
printAll(x=4, y=5)
#輸出:
a : 1
c : 3
b : 2
y : 5
x : 4

python的中參數可以多種形式進行組合, 在混合使用時,首先要注意函數的寫法,必須遵守:

1.帶有默認值的形參(arg=)須在無默認值的形參(arg)之后
2.元組參數(*args)須在帶有默認值的形參(arg=)之后
3.字典參數(**kargs)須在元組參數(*args)之后

在函數被調用時,參數的傳遞過程為:

1.按順序把無指定參數的實參賦值給形參
2.把指定參數名稱(arg=v)的實參賦值給對應的形參
3.將多余的無指定參數的實參打包成一個 tuple 傳遞給元組參數(*args)
4.將多余的指定參數名的實參打包成一個 dict 傳遞給字典參數(**kargs)

8. lambda 表達式
lambda 表達式可以看做一種匿名函數
    lambda 表達式的語法格式:
    lambda 參數列表: 表達式   #參數列表周圍沒有括號,返回值前沒有 return 關鍵字,也沒有函數名稱

復制代碼 代碼如下:

def fn(x):
    return lambda y: x + y
#調用
a = fn(2)
print a(3)
#輸出
5

分析
: fn(2)調用后, 相當于a = lambda y: 2 + y, 然后a(3)被調用時.
相當于 print lambda y: 2 + 3

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 陇南市| 岑溪市| 绥棱县| 广州市| 甘谷县| 梁山县| 积石山| 壶关县| 梅州市| 定兴县| 文化| 和林格尔县| 靖边县| 岳普湖县| 杨浦区| 安图县| 洪洞县| 安图县| 凤冈县| 政和县| 和林格尔县| 竹溪县| 秀山| 巧家县| 台州市| 洱源县| 武清区| 芜湖县| 双峰县| 连州市| 揭阳市| 崇义县| 宝坻区| 礼泉县| 商城县| 丹东市| 陆良县| 云林县| 凌海市| 开原市| 湖州市|