python使用建議與技巧分享(一)
這是一個系列文章,主要分享python的使用建議和技巧,每次分享3點,希望你能有所收獲。
1 如何創建指定長度且有特定值的list
不推薦方式
list1 = [0, 0, 0, 0, 0, 0, 0, 0, 0, 0]print list1# [0, 0, 0, 0, 0, 0, 0, 0, 0, 0]
推薦方式
list1 = [0] * 10print list1# [0, 0, 0, 0, 0, 0, 0, 0, 0, 0]
其實,前一種方式一看就不符合DRY(Don’t Repeat Yourself)原則,稍微想想就知道還有更優雅的做法。如果是元組呢?只需要將[0]改成(0,)即可,千萬不要忘記0后面的逗號。另外,這里不止支持數字,其實可以是任意對象組成的list或者tuple。例如:
class User(object):passuser_list = [User()] * 10
2 如何連接字符串
不推薦方式
def plus_str():str_list = [’1’] * 10000long_str = ’’for str in str_list:long_str = long_str + strreturn long_str
推薦方式
def join_str():str_list = [’1’] * 10000return ’’.join(str_list)
使用加號方式連接字符串,效率底下,因為會頻繁的拷貝字符串和分配內存,比較耗時。但是使用join方式連接字符串,只需要分配一次內存,并將所有待連接的字符串拷貝到內存空間,效率更高。在我的電腦上,測試2個函數的耗時,當執行10000次時,前者耗時是后者約24倍,代碼如下:
print timeit(stmt='plus_str()',setup='from __main__ import plus_str',number=10000)// 輸出:42.7354210396print timeit(stmt='join_str()',setup='from __main__ import join_str',number=10000)// 輸出: 1.78316799643
3 如何合并字典
不推薦方式
dict1 = {’a’: 1, ’b’: 2, ’c’: 3}dict2 = {’a’: 4, ’b’: 5, ’g’: 6}dict1.update(dict2)merged_dict = dict1print merged_dict# {’a’: 4, ’c’: 3, ’b’: 5, ’g’: 6}
推薦方式
dict1 = {’a’: 1, ’b’: 2, ’c’: 3}dict2 = {’d’: 4, ’f’: 5, ’g’: 6}merged_dict = dict(dict1, **dict2)print merged_dict# {’a’: 1, ’c’: 3, ’b’: 2, ’d’: 4, ’g’: 6, ’f’: 5}
前一種方式會將源字典dict1修改,有一定的副作用,如果不在乎源字典被修改,前一種方式更簡潔一些。后一種方式不會修改源字典,沒有副作用。如果有重復的key值,按從右到左的順序覆蓋,例如:
dict1 = {’a’: 1, ’b’: 2, ’c’: 3}dict2 = {’a’: 4, ’b’: 5, ’g’: 6}merged_dict = dict(dict1, **dict2)print merged_dict# {’a’: 4, ’c’: 3, ’b’: 5, ’g’: 6}
使用右邊參數dict2的key值覆蓋dict1的key值。通過內建函數dict,將2個字典作為參數傳遞給該函數,創建一個新字典。需要特別指出的是,第二個參數dict2需要加上2個星號,這里表示該參數是一個具名參數,并且類型是字典。因為dict函數創建字典時,可以接受多個參數,這是python函數支持可變參數的規定格式。
以上就是python使用建議與技巧分享(一)的詳細內容,更多關于python 建議與技巧的資料請關注好吧啦網其它相關文章!
相關文章: